天天看点

类和动态内存分配

Part 1:

静态类成员特点:

无论创建了多少对象,程序都只创建一个静态类变量副本。也就是说,类的所有对象共享一个静态成员。

静态数据成员在类声明中声明,在包含类方法的文件中初始化。初始化时使用作用域运算符来指出静态成员所属的类。

但如果静态成员是const整数类型或枚举型,则可以在类声明中初始化。

Part 2:在构造函数中使用new时注意事项

1、 new && delete

  1. 如果在构造函数中使用new来初始化指针成员,则应在析构函数中使用delete;
  2. new和delete必须相互兼容。new对应于delete,new[]对应于delete[];
  3. 如果有多个构造函数,则必须以相同的方式使用new,要么都带中括号,要么都不带,因为只有一个析构函数,所有的构造函数都必须与它兼容;然而,可以在一个构造函数里使用new初始化指针,而在另一个构造函数里将指针初始化为空,这是因为delete可以用于空指针。

2、 Demo

class Act{…};

Act nice【1】; //外部对象

int main()

{

Act *pt【2】=new Act; //动态对象

{

Act up【3】; //自动化对象

}

delete pt;

}

说明:

【3】执行到定义代码块末尾时,将调用自动对应的up的析构函数

【2】对指针pt应用运算符delete时,将调用动态对象*pt的析构函数

【1】 整个程序结束时,将调用静态对象nice的析构函数

如果对象是静态变量,则在程序结束时将调用对象的析构函数。

Part 3: 复制构造函数

应定义一个复制构造函数,通过深度复制将一个对象初始化为另一个对象。

具体来说:复制构造函数应分配足够的空间来存储复制的数据,并复制数据,而不仅仅是数据的地址;另外,还应该更新所有受影响的静态类成员。

应当定义一个赋值运算符,通过深度复制将一个对象复制给另一个对象。

Demo:

String::String(const String & st) //st是新的对象

{

num_string++; //静态成员变量

len=st.len;

str=new char[len+1];

std::strcpy(str,st.str);

}

String & String::operator=(const String & st)

{

if(this == &st)

{

return *this;

}

delete[] str;

len=st.len;

str=new char[len+1];

std::strcpy(str,st_str);

return *this;

}

继续阅读