我做了一个简单的类只是为了在C ++中尝试转换构造函数。
它显然有效,但在进行某项操作时,似乎编译器没有调用它。我会知道为什么,或者也许我错了。
#include <iostream>
using std::cout; using std::endl;
class CostruttoreConversione
{
public:
CostruttoreConversione(int val = 0)
{
cout << "Costruttore chiamato" << endl;
valore = val;
}
inline int getValore(){
return valore;
}
CostruttoreConversione provaConversioneImplicita()
{
return -10; //here the type *should* be converted; doesn't happen.
}
private:
int valore;
};
int main(void){
CostruttoreConversione obj(10);
cout << "obj = " << obj.getValore() << endl;
obj = 20; //WORKS
cout << obj.getValore() << endl;
// cout << obj.provaConversioneImplicita() << endl; doesn't work.
return 0;
}
答案 0 :(得分:2)
构造应该有效,但是输出操作失败了,因为你还没有为你的类定义一个输出操作符。
你仍然可以这样做。
cout << obj.provaConversioneImplicita().getValore() << endl;
或者您定义输出运算符:
inline std::ostream& operator<<(std::ostream& os, const CostruttoreConversione& cc)
{
os << cc.getValore();
return os;
}
答案 1 :(得分:1)
您可以重载转换运算符,以便CostruttoreConversione可以转换为int。
class CostruttoreConversione{
operator int() const{
return valore;
}
}
还要写一个复制构造函数
答案 2 :(得分:0)
默认构造函数和参数化构造函数一起构成转换构造函数。 例如, 如果您正在编写用于创建ADT阵列的程序, 当你在函数main中声明一个数据类型数组的变量时, main调用参数化构造函数,该构造函数将数组转换为用于开发数组的数据类型。 所以间接转换正在发生。 因此,不会调用转换构造函数。 但默认和参数化构造函数在内部进行转换。