默认模板参数和部分专用化
Default template argument and partial specialization
请向我解释为什么以下代码符合并完美运行。我很困惑。
#include<iostream>
template<class A = int, class B=double>
class Base
{};
template<class B>
class Base <int, B>
{
public:
Base()
{
std::cout<<"it works!!!!!n";
}
};
int main()
{
Base<> base; // it prints "it works!!!!!"
return 0;
}
它不应该属于模板类 Base 的广义形式吗?
默认参数适用于专用化 -- 事实上,专用化必须接受(可以这么说)基本模板的默认参数。尝试在专用化中指定默认值:
template<class A = int, class B=double>
class Base
{};
template<class B=char>
// ...
。是一个错误。
同样,如果我们更改专用化,使其专用化适用于基本模板提供的默认值以外的类型:
template<class A = int, class B=double>
class Base
{};
template<class B>
class Base <char, B>
。然后将选择基本模板。
所以,正在发生的事情是这样的:首先选择模板参数的类型。在这种情况下(实例化时未指定任何类型),这两种类型都基于基模板中指定的默认模板参数。
然后(作为一个基本上独立的步骤)它在适合这些参数类型的所有模板上执行重载解析的模拟。与重载解析的常规情况一样,显式指定的类型优先于隐式指定的类型,因此您的专用化(显式指定int
)优先于基本模板(int
隐式指定)。
template<class A = int, class B=double>
class Base
{};
这里 A 和 B 的默认值/初始化分别声明为 int 和 double。
template<class B>
class Base <int, B>
在类定义中,第一个参数类似于常量值(这里是int;为什么以这种方式声明只是让事情变得复杂?最好删除第一个模板参数),第二个模板参数是默认值为"双精度"的 B。
Base<> base;
创建类的对象时。虽然您没有指定模板参数,但编译器采用参数(A 和 B)的默认值,即"int"和"double",并且代码执行时没有任何错误或警告。
查看将对象创建为时会发生什么情况:
Base<float,char> b;
或Base<char,char> b;
当你编写Base<> base;
编译器将尝试找出是否可以实例化Base<>
类,如果代码可以正常工作。在这种情况下,由于默认模板参数为 Base 是可能的,因为编译器知道您是否编写Base<>
它需要创建一个 Base<int,double>
的对象。即:因为:
template<class A = int, class B=double>
class Base
{};
所以代码工作正常。
TL;DR:
template<class A = int, class B=double> class Base {}
- 此行定义主模板。主模板必须更通用。在这种情况下,它接受任何类型的 A 和 B,即
Base<> base;
- 同时,
A = int
和B = double
是默认值,这意味着在没有模板参数的情况下实例化Base<> base
实际上是Base<int, double> base
。 - 然后第一个参数
int
恰好匹配Base <int, B>
,部分专用模板,因此调用"它工作"函数。
- 具有常量引用参数的函数模板专用化
- 通过依赖类型使用非类型模板参数的单类型模板参数类模板的部分专用化
- 具有多个参数的模板化类专用化,其中一个模板参数是模板本身
- 具有可变参数非类型参数的模板专用化
- 类专用化,没有用作专用化模板参数的类的模板参数
- 基于枚举参数调用专用模板方法
- 检查类是否具有模板专用化(使用布尔值或 int 等模板参数)
- 专用于可变参数模板成员函数
- 如何将模板类专用化为也接受模板模板参数
- 调用模板专用化,具有更多参数的单参数模板调用的特定值
- 有没有办法根据 lambda 参数返回类型部分专用化我的模板化函数?
- C++ 将派生类的成员函数指针作为参数传递时选择了错误的模板专用化
- cpp 模板专用化,错误说参数 1 的类型为 T,这取决于参数 T
- 具有不同非类型模板参数的模板类部分专用化
- 带有void类型和参数的C++11模板专用化
- 类模板专用化演绎是否应该考虑演绎指南参数初始化?
- 使用模板模板参数进行模板定义的函数专用化
- 在模板专用化中使用非类型模板模板参数
- C++具有可变参数专用参数的模板,用于参数数量
- 具有专用参数的类方法