不知道怎么关闭优化,直接使用比较老的Vc++6.0,结果是调用了拷贝构造函数。 #include <iostream> #include <memory> using namespace std; class HasPtr{ public: HasPtr() { } HasPtr( int i1,string &str ){ i = i1; ps = &str; } HasPtr( HasPtr& hp){ i = hp.i; ps = new string( *hp.ps ); cout<<"调用拷贝构造函数"<<endl; } HasPtr& operator=( HasPtr& hp){ cout<<"调用拷贝赋值运算符"<<endl; i = hp.i; ps = hp.ps; return *this; } int i; string *ps; }; int main( ){ string str = "hello"; HasPtr hp4 = HasPtr(1,str); cout<<"hp4建立完成"<<endl; HasPtr hp1(1,str); HasPtr hp2 = hp1; cout<<"hp3拷贝初始化完成"<<endl; HasPtr hp3; hp3 = hp1; HasPtr* hp5 = new HasPtr(1,str); return 0; } 输出  调用拷贝构造函数  hp4建立完成  调用拷贝构造函数  hp3拷贝初始化完成  调用拷贝赋值运算符  这里HasPtr( HasPtr& hp)去掉了const,也是对的,本来就觉得这里可以不用const修饰 奇怪的是用eclipse,如果说没使用拷贝构造函数为什么忽略掉const就报错, 没调用的话怎么会报错?而且原因也不知道  #include <iostream> #include <memory> using namespace std; class HasPtr{ public: HasPtr() = default; HasPtr( int i1,string &str ){ i = i1; ps = &str; } HasPtr(/*const*/ HasPtr& hp){ i = hp.i; ps = new string( *hp.ps ); cout<<"调用拷贝构造函数"<<endl; } int i; string *ps; }; int main( ){ string str = "hello"; HasPtr hp4 = HasPtr(1,str); cout<<hp4.i<<" "<<*hp4.ps<<endl; return 0; } 上面的代码eclipse报错:invalid initialization of non-const reference of type 'HasPtr&' from an rvalue of type 'HasPtr' 如果删除掉自己定义的拷贝构造函数,使用默认的不会报错。
点赞 2
牛客网
牛客企业服务