标签:调用 const cout 函数调用 运算符 拷贝 TestCopy 赋值
拷贝构造函数中写该对象各个值等于被拷贝对象的各个值,像这样
TestCopy::TestCopy(const TestCopy& t)
{
a=t.a;
cout << "调用了拷贝函数" << endl;
}
而内部写成这样也是可以走通的
TestCopy::TestCopy(const TestCopy& t)
{
*this = t;
cout << "调用了拷贝函数" << endl;
}
所以为什么呢?是调用了默认的赋值运算符吗?
然后做了一下测试:
TestCopy::TestCopy(const TestCopy& t)
{
cout<<"调用前"<<endl;
*this = t;
cout<<"调用后"<<endl;
cout << "调用了拷贝函数" << endl;
}
TestCopy & TestCopy::operator=(const TestCopy& p)
{
if (this == &p)
return *this;
a = p.a;
cout << "调用了赋值构造函数" << endl;
return *this;
}
运行main()
int main()
{
TestCopy t1;
TestCopy t2 = (t1);
}
调用前
调用了赋值构造函数
调用后
调用了拷贝函数
嗯 ,确实。
标签:调用,const,cout,函数调用,运算符,拷贝,TestCopy,赋值 来源: https://blog.csdn.net/zsfhrd/article/details/120863679
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。