构造函数自动推导模板的类型
C++中很多类都需要指定类型,其实这个类型可以从用户所调用的构造函数中推导出来。不过,在C++17之前,这是一个未标准化的特性。C++17能让编译器自动的从所调用的构造函数,推导出模板类型。
How to do it...
使用最简单的方法创建std::pair
和std::tuple
实例。其可以实现一步创建。
How it works...
让我们定义一个类,了解自动化的对模板类型进行推断的价值。
好!我们定义了一个模板类。C++17之前,我们为了创建该类的实例:
我们省略模板特化的部分:
C++17之前,我们可能会通过以下的方式实现一个工厂函数:
使用工厂函数:
Note:
STL中有很多工厂函数,比如
std::make_shared
、std::make_unique
、std::make_tuple
等等。C++17中,这些工厂函数就过时了。当然,考虑到兼容性,这些工厂函数在之后还会保留。
There's more...
我们已经了解过隐式模板类型推导。但一些例子中,不能依赖类型推导。如下面的例子:
结构体中,sum
能接受任意数量的参数,并使用折叠表达式将它们添加到一起(本章稍后的一节中,我们将讨论折叠表达式,以便了解折叠表达式的更多细节)。加法操作后得到的结果保存在value
变量中。现在的问题是,T
的类型是什么?如果我们不显式的进行指定,那就需要通过传递给构造函数的变量类型进行推导。当我们提供了多个字符串实例,其类型为std::string
。当我们提供多个整型时,其类型就为int
。当我们提供多个整型、浮点和双浮点时,编译器会确定哪种类型适合所有的值,而不丢失信息。为了实现以上的推导,我们提供了指导性显式推导:
指导性推导会告诉编译器使用std::common_type_t
的特性,其能找到适合所有值的共同类型。来看下如何使用:
第1行中,我们创建了一个sum
对象,构造函数的参数类型为unsigned
, double
, int
和floa
t。std::common_type_t
将返回double
作为共同类型,所以我们获得的是一个sun<double>
实例。第2行中,我们创建了一个std::string
实例和一个C风格的字符串。在我们的指导下,编译器推导出这个实例的类型为sum<std::string>
。
当我们运行这段代码时,屏幕上会打印出10和abcdef。其中10为数值sum
的值,abcdef为字符串sum
的值。
Last updated