先上代码
template <typename T>
class A
{
public:
A()
{
cout << "A()" << endl;
}
A(const A& a)
{
cout << "A(const A& a)" << endl;
}
template <typename U, typename... Args>
A(U & f, Args... arg)
{
cout << "A(U & f, Args... arg)" << endl;
}
};
int main()
{
A<int> a; //A()
A<int> b(a); //A(U & f, Args... arg)
return 0;
}
如果修改一下
template <typename U, typename... Args>
A(U f, Args... arg)
{
cout << "A(U & f, Args... arg)" << endl;
}
那么输出就变成了想要的方式了。
A()
A(const A& a)
为什么构造对象b的时候会调用A(U & f, Args... arg)
这个模板函数,而不是调用拷贝构造函数?
应该如何指定调用的构造函数?
這個應該和C++選擇重載函數的順序有關,對於一個型別 T 的實參,優先選擇 T&,然後才是 const T& 吧。
所以如果你把程式碼修改成:
它也會先執行
A(const A& a)
的。