类和动态内存分配

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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值