我对以下代码有疑问(这是一个非常简化的示例,可以在我的程序中重现错误):
#include <iostream>
using namespace std;
template<class T> class CBase
{
public:
template <class T2> CBase(const T2 &x) : _var(x) {;}
template <class T2> CBase (const CBase<T2> &x) {_var = x.var();}
~CBase() {;}
T var() const {return _var;}
protected:
T _var;
};
template<class T> class CDerived : public CBase<T>
{
public:
template <class T2> CDerived(const T2 &x) : CBase<T>(x) {;}
template <class T2> CDerived (const CBase<T2> &x) : CBase<T>(x) {;}
~CDerived() {;}
};
int main()
{
CBase<double> bd(3);
CBase<int> bi(bd); // <- No problem
CDerived<double> dd1(3);
CDerived<double> dd2(dd1);
CDerived<int> di(dd1); // <- The problem is here
return 0;
}
错误如下:
error: cannot convert 'const CDerived<double>' to 'int' in initialization
如何解决?(优先在基类中而不是在派生类中进行修改,并且尽可能不使用虚拟性)
非常感谢你
编辑:如果我将相关行替换为:CDerived<int> di(CBase<int>(CBase<double>(dd1)));
它可以工作,但它不是很实用......
编辑:似乎可以解决:
template <class T2> CDerived(const CDerived<T2> &x) : CBase<T>(static_cast<const CBase<T2>&>(x)) {;}