先上代码
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)
も最初に実行されます。