c/c++拷贝构造函数和关键字explicit详解
2019/7/10 22:33:30
本文主要是介绍c/c++拷贝构造函数和关键字explicit详解,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
关键字explicit
修饰构造方法的关键字,加上了,就告诉编译器,不可以隐式初始化对象;不加就可以隐式初始化对象;
下面的代码是可以正常编译执行的,但是加了关键字explicit,编译就会错我,因为Test t = 100;是隐式初始化对象,但是如果加上强制类型转换后,就不会有错误了。
强制类型转换:Test t = (Test)100;
class Test{ public: Test(int d):data(d){//explicit cout << "C:" << this << endl; } } int main(){ Test t = 100; } 拷贝构造函数如果加上了explicit,下面的语句就无法编译通过;不加可以。 class Test{ public: //拷贝构造函数 explicit Test(const Test &t){ data = t.data; } int getData(){ return data; } private: int data; }; void test(Test x){ } int main(){ Test t2(t1);//调用拷贝构造函数 //Test t3 = t2;//编译不过 //test(t2);//编译不过 }
触发拷贝构造函数的4种方式
1,Test t2(t1);//调用拷贝构造函数
2,声明的同时就赋值Test t3 = t2会调用拷贝构造函数;但是注意下面这种不会调用拷贝构造函数。
Test t3;
t3 = t2;//会调用=的重载方法
3,方法的参数是对象类型test(t2);
4,方法的返回值是对象类型。原因:对象tmp在方法结束后就被释放掉了,要返回到函数外,必须要复制tmp.
但是用gdb看了一下在return处并没有调用拷贝构造函数,所以test方法结束后,tmp也没有被释放,调用test方法的t5的内存地址和tmp是一样的。个人猜测:老版本的gcc编译器可能会在return处调用拷贝构造函数,但是新的编译器(gcc 4.8.5-20)为了提高效率,避免了一次多余的拷贝。
void test(Test x){//进入函数的时点会调用拷贝构造函数 int value; value = x.getData(); Test tmp(value); return tmp;//return的时点会调用拷贝构造函数 } Test t5 = test(t1);
这篇关于c/c++拷贝构造函数和关键字explicit详解的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享