欢迎来到代码驿站!

C代码

当前位置:首页 > 软件编程 > C代码

c/c++拷贝构造函数和关键字explicit详解

时间:2020-11-26 22:58:09|栏目:C代码|点击:

关键字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代码

下一篇:详解Visual Studio 2019(VS2019) 基本操作

本文标题:c/c++拷贝构造函数和关键字explicit详解

本文地址:http://www.codeinn.net/misctech/26644.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有