模板化构造函数是否覆盖C中的隐式复制构造函数?

模板化构造函数(如下所示)是否会覆盖隐式复制构造函数
template <class T>
struct Foo
{
    T data;

    // ...

    template <class U>
    Foo(const Foo<U> &other) : data((T)doSomethingWith(other.data)) {}

    // ...
};

如果是这样,如果通过值而不是常量引用传递其他值,它是否仍会覆盖它?

如果是这样,有没有明确定义复制构造函数方法呢?

解决方法

不,那不是复制构造函数.本标准第12.8节([class.copy])要求:

A non-template constructor for class X is a copy constructor if its first parameter is of type X&,const X&,volatile X& or const volatile X&,and either there are no other parameters or else all other parameters have default arguments.

编译器仍将隐式生成认值.

你可以明确(需要C 11)

Foo(const Foo<T>&) = default;

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...