重载<<运算符
作用:可以使用它和cout一起用来显示对象的内容。一般使用该类的友元函数来重载该运算符,因为调用这个函数的对象不是类对象。但是如果该类提供了能够返回所需内容的共有方法,则可以在运算符函数中使用这些方法,这样也就不用将其设置为友元函数。
转换函数
要将单个值转换成类类型,函数原型如下:
类名(type_name value);
要将类转换成其他类型,函数原型如下:
operator type_name();//这里的type_name已经指出了要将类类型转化的类型,所以不需要提供返回值类型。而且转换函数是类成员函数,通过类对象来调用,所以其不需要参数。
虽然该函数没有返回值类型,但应返回所需类型的值。使转换函数可以使用explicit,以防止它被用于隐式转换。
其构造函数使用new的类
如果类使用new运算符来分配类成员指向的内存,在设计时应该采用一些预防措施:
(1)对于指向的内存是new来分配的所有类成员(注意是类成员,不是类对象),都应该在类的析构函数中对其使用delete,该运算符将释放分配的内存。
(2)如果析构函数通过对指针类成员使用delete来释放内存,则每个构造函数都应该使用new来初始化指针,或者将其设置为空指针。
(3)构造函数汇总的new和new[ ]与析构函数中的delete和delete[ ]应该一一对应。new对应于delete,new[ ]对应于delete [ ]。
(4)应定义一个分配内存(而不是一个将指针指向已有内存)的复制构造函数。这样程序能够精类对象初始成另一个对象。这种构造函数的原型一般是classname(const classname &)。例如类成员中有指针,以字符串为例,应该在复制构造函数中先使用new为其开辟一个内存空间,人然后使用strcpy()函数对数据本身(而不是对其指针)进行复制粘贴。
(5)应该定义一个重载赋值运算符的类成员,其函数定义(复制构造函数相似)如下:
c_name & c_name::operator = (const c_name & cn)
{
if(this == &cn)
return *this;//它首先检查自我复制(此处使用了this指针,所有的类方法都将this指针设置为调用它的对象的地址,地址相同就返回this指针并结束函数
delete [] c_pointer;//释放c_pointer指向的内存
//设置要复制的type_name单元的大小
c_pointer = new type_name[size];
//然后再将数据复制到cn.c_pointer指向的内存中。
return *this;
}