第十二章 类和动态内存分配
12.1 动态内存和类
动态内存分配让程序运行时决定内存分配。C++使用new和delete来动态控制内存。
12.1.1 复习示例和静态类成员
12.1.2 特殊成员函数
默认构造函数
复制构造函数(将一个对象复制到新创建的对象)
复制构造函数原型:
Class_name(consr Class_name &);
新建一个对象并将其初始化为同类现有对象时,将调用复制构造函数。
默认的复制构造函数
逐个复制非静态成员
12.1.3 回到StringBad:复制构造函数的哪里出了问题
12.1.4 StringBad的其他问题:赋值运算符
12.2 改进后的新String类:
12.3 在构造函数中使用new时的注意事项
new和delete应该对应。
定义一个复制构造函数。(深度复制)
定义一个赋值运算符。(深度复制)
12.4 有关返回对象的说明
返回指向const对象的引用旨在提高效率。
在重载赋值运算符和重载和cout一起用的<<运算符返回指向非const对象的引用。
返回的对象是调用函数的局部变量时返回对象。
12.5 使用指向对象的指针
使用常规表示法来声明指向对象的指针。
可以将指针初始化为指向已有对象。
对类使用new运算符将调用相应的类构造函数来初始化新创建的对象。
可以使用->运算符通过指针访问类方法。
对指针使用*获得对象。
12.5.3 再谈定位new运算符。
程序员需要提供两个位于缓冲区的不同地址,并确保两个地址不重叠。
例如:
pc1 = new(buffer) JustTesting;
pc3 = new(buffer + sizeof(JustTesting)) JustTesting;
删除时 显式调用析构函数,且与创建顺序相反。
12.6 复习各项技术
12.6.1 重载<<运算符
12.6.2 转换函数
将单个值转换为类类型,创建如下类构造函数:
c_name(type_name value);
将类转换为其他类型,创建如下类成员函数:
operator type_name(); //虽然没有声明返回类型,但是应返回所需类型的值。
12.6.3 其构造函数使用new的类
内存由new分配的类成员,在类的析构函数对其使用delete、
析构函数使用delete的指针类成员,构造函数应当使用new来初始化指针,或设置为空指针。
构造函数new[] 或new 不能混用。析构函数对应构造函数。
应定义一个分配内存的复制构造函数。className(const className&)
应定义一个重载赋值运算符的类成员函数。
c_name& c_name::operator=(const c_name& cn)
{
if(this == &cn)
return *this;
delete [] c_pointer;
c_pointer = new type_name[size];
//copy data...
return *this;
}
12.7 队列模拟