模板化构造函数是否覆盖C++中的隐式复制构造函数
Does a templated constructor override the implicit copy constructor in C++?
模板化构造函数(如下所示)是否覆盖隐式复制构造函数?
template <class T>
struct Foo
{
T data;
// ...
template <class U>
Foo(const Foo<U> &other) : data((T)doSomethingWith(other.data)) {}
// ...
};
如果是这样,如果other
按值而不是常量引用传递,它是否仍会覆盖它?
如果是这样,在不显式定义复制构造函数的情况下有什么方法可以解决这个问题吗?
不,这不是复制构造函数。 标准第12.8([class.copy]
)节要求:
编译器类
X
的非模板构造函数是复制构造函数,如果它的第一个参数是X&
、const X&
、volatile X&
或const volatile X&
的类型,并且没有其他参数,或者所有其他参数都有默认参数。
仍将隐式生成默认的编译器。
您可以通过以下方式明确(需要 C++11)
Foo(const Foo<T>&) = default;
模板化构造函数(如下所示)是否覆盖隐式复制构造函数?
不。复制构造函数仍然是隐式声明的,并且优先选择模板。
在不显式定义复制构造函数的情况下,有什么办法可以解决这个问题吗?
不。如果您不想要隐式复制构造函数,则必须自己定义一个。
看起来像
模板化 [默认构造函数/复制构造函数/移动构造函数/复制赋值运算符/移动赋值运算符] 的模板化构造函数或赋值运算符并不是真正的 [默认构造函数/复制构造函数/移动构造函数/复制赋值运算符/移动赋值运算符],并且不会替换它或阻止它隐式生成。
相关文章:
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 当从函数参数中的临时值调用复制构造函数时
- 如果有一个模板构造函数只有一个泛型参数,为什么我必须有一个复制构造函数
- 使用复制构造函数复制双精度数组
- C 无可行的构造函数复制类型的变量
- 没有可行的构造函数复制类型 'MyString' 的数组元素
- 编译时,复制构造函数/复制分配和正常功能调用优化之间是否存在任何区别
- 如何最小化调用列表构造函数(复制构造函数)的次数?
- C 11矢量构造函数复制与范围
- 我定义了一个非复制构造函数;复制构造函数还会被隐式定义吗
- 可以将构造函数复制为转换运算符
- 将基类指针的构造函数复制到子类
- C++树类:构造函数/复制/内存泄漏
- 如何制作这个在模板构造函数复制中使用类型定义的类型的模板
- 将构造函数复制为模板化的成员函数
- 绕过私有复制构造函数/复制赋值C++
- C++通过构造函数复制对象
- 复制构造函数 - 复制C++中的对象
- 将带unique_ptr的类的构造函数复制到作为成员的抽象类