c++primer plus 6 读书笔记 第十二章 类和动态内存分配

  第十二章 类和动态内存分配

12.1 动态内存和类

动态内存分配让程序运行时决定内存分配。C++使用new和delete来动态控制内存。

12.1.1 复习示例和静态类成员

12.1.2  特殊成员函数

  1. 默认构造函数
  2. 复制构造函数(将一个对象复制到新创建的对象)

复制构造函数原型:

Class_name(consr Class_name &);

新建一个对象并将其初始化为同类现有对象时,将调用复制构造函数。

  1. 默认的复制构造函数

逐个复制非静态成员

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 队列模拟

 

你可能感兴趣的:(C++,学习笔记)