运算符重载妙用

王朝other·作者佚名  2006-01-08
宽屏版  字体: |||超大  

运算符重载的妙用:

考虑下面一个题目:

有这样一个类。

class myclass

{

public:

myclass();

~myclass();

private:

BYTE *m_data; //存储数据

};

由于m_data是动态分配内存的,当使用者这样使用时:

myclass a1;

…..

myclass a2;

a2 = a1;

显然,这里存在一个问题,请指出问题在哪里?

如果要简单地避免这个问题,你会怎么去做?

这里的问题是对于类myclass,由于没有重载运算符=号,C++编译器会为其添加一个默认的运算符=;这个函数执行默认的拷贝操作位拷贝,即当调用a2 = a1;时会将a1所分配的内存完全拷贝到a2中,这是a2的m_data指向a1的m_data;与等号的原意不符,希望的时二者m_data指向内存的大小和内容相同;并且,如果a1先与a2销毁,a2的m_data则指向一个非法内存,对齐操作会导致程序运行出错。

如果要避免这个问题,最简单的办法便是重载预算府等号,并且不写其实现,定义为私有接口,这样使用者调用a2=a1时会得到一个编译错误,避免了默认拷贝的危险。

修改后的类是这样的。

class myclass

{

myclass operator=(const myclass a){};

public:

myclass();

~myclass();

private:

BYTE *m_data; //存储数据

};

这是程序设计的一个思想:将错误暴露在编译期间。如果不愿意使用者使用默认的拷贝构造函数和=号运算,请显式声明它为私有接口。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有