C++ 拷贝构造函数、赋值运算符=的调用时机
C++  /  houtizong 发布于 3年前   283
#include <iostream>using namespace std;class Class{public:Class(){}//如果用 explicit Class(const Class& c){ 来声明,则不能用Class c1=c;而只可以Class c2(c); Class(const Class& c){cout<<"copy construnctor called\n";}//=的调用者本身就是个Class类!该函数只是为了自行完成一些数据传递的任务,最后返回该调用者的引用即可Class& operator=(const Class& c){cout<<"= operator called\n";return *this;}//函数返回时调用拷贝构造函数static Class getClass(){cout<<"begin getClass\n";Class c;cout<<"end of getClass,soon to return\n";return c;}};//类作为参数,进入函数时会调用拷贝构造函数void classAsParam(Class c){cout<<"begin classAsParam\n";}//类的引用作为参数,进入函数时不会调用拷贝构造函数void classReferenceAsParam(Class& c){cout<<"begin classReferenceAsParam\n";}void main(){Class c;Class c1=c;//因为是初始化,调用的是拷贝构造函数,而非=运算符Class c2(c);//同上cout<<"\n//////////// Test getClass without return value\n";Class::getClass();//函数返回时调用拷贝构造函数cout<<"\n//////////// Test getClass with new left value\n";Class c3=Class::getClass();//函数返回时调用拷贝构造函数;由于c3在此声明,因而再调用拷贝构造函数(貌似被编译器省略了)cout<<"\n//////////// Test getClass with exist left value\n";c2=Class::getClass();//函数返回时调用拷贝构造函数;由于c2已经声明过,因而再调用=运算符将临时变量赋值给c2cout<<"\n//////////// Test classAsParam\n";classAsParam(c);//类作为参数,进入函数时会调用拷贝构造函数cout<<"\n//////////// Test classReferenceAsParam\n";classReferenceAsParam(c);//类的引用作为参数,进入函数时不会调用拷贝构造函数}
请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!
技术博客集 - 网站简介:
前后端技术:
后端基于Hyperf2.1框架开发,前端使用Bootstrap可视化布局系统生成
网站主要作用:
1.编程技术分享及讨论交流,内置聊天系统;
2.测试交流框架问题,比如:Hyperf、Laravel、TP、beego;
3.本站数据是基于大数据采集等爬虫技术为基础助力分享知识,如有侵权请发邮件到站长邮箱,站长会尽快处理;
4.站长邮箱:[email protected];
文章归档
文章标签
友情链接