您的位置:首页 > 其它

为什么要自己写构造函数和析构函数

2014-04-28 18:01 225 查看
为什么要自己写构造函数和析构函数

“缺省的拷贝构造函数”和“缺省的赋值函数”均采用“位拷贝”而非“值拷贝”

的方式来实现,倘若类中含有指针变量,这两个函数注定将出错。
 

类的const 常量只能在初始化表里被初始化,因为它不能在函数体内用赋值的方式来初始化

拷贝构造函数是在对象被创建时调用的,而赋值函数只能被已经存在了的对象调用

String a(“hello”);

String b(“world”);

String c = a; // 调用了拷贝构造函数,最好写成 c(a);

c = b; // 调用了赋值函数 

    如果不主动编写拷贝构造函数和赋值函数,编译器将以“位拷贝”的方式自动生成缺省的函数。倘若类中含有指针变量,那么这两个缺省的函数就隐含了错误。以类String 的两个对象a, b 为例,假设a. m_ data 的内容为“hello”,b .m _data 的内容为“world”。现将a 赋给b,缺省赋值函数的“位拷贝”意味着执行b .m _data = a. m_ data。这将造成三个错误:一是b. m_ data 原有的内存没被释放,造成内存泄露;二是b. m_ data 和a. m_ data 指向同一块内存,a 或b 任何一方变动都会影响另一方;三是在对象被析构时,m_ data 被释放了两次。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐