已知类String的原型为:
class String
{
public:
String(const char *str = NULL) ; //普通构造函数
String(const String &other) ; //复制构造函数
~String(void) ; //析构函数
String & operator = (const String &other) ; //赋值函数
private:
char * m_String ; //私有成员,保存字符串
}
类String的构造函数、析构函数和赋值函数的程序代码如下:
#include <iostream>
using namespace std ;
class String
{
public:
String(const char *str = NULL) ; //普通构造函数
String(const String &other) ; //复制构造函数
~String(void) ; //析构函数
String & operator = (const String & other ) //赋值函数
private:
char * m_String ; //私有成员,保存字符串
}
String::~String(void)
{
cout<<"Destructing"<<endl ;
if(m_String != NULL) //如果m_String不为NULL,释放堆内存
{
delete [] m_String ;
m_String = NULL ; //释放后置为NULL
}
}
String::String(const char *str)
{
cout<<"Constructing"<<endl ;
if(str == NULL) //如果str为NULL,存空字符串""
{
m_String = new char[1] ; //分配一个字节
*m_String = '\0' ; //将之赋值为字符串结束符
}
else
{
m_String = new char[strlen(str) + 1] ; //分配空间容纳str内容
strcpy(m_String,str) ; //复制str到私有成员
}
}
String::String(const String &other)
{
cout<<"Constructing Copy" <<endl ;
m_String = new char[strlen(other.m_String) + 1] ; //分配空间容纳str内容
strcpy(m_String,other.m_String) ; //复制str到私有成员
}
String &String::operator = (const String &other)
{
cout<<"Operator = Function" <<endl ;
if(this == &other) //如果对象与other是同一个对象
{
return *this ; //直接返回本身
}
delete [] m_String ; //释放堆内存
m_String = new char[strlen(other.m_String)+1] ;
strcpy(m_String,other.m_String);
return *this ;
}
int main()
{
String a("hello") ; //调用普通构造函数
String b("world") ; //调用普通构造函数
String c(a) ; //调用复制构造函数
c = b ; //调用赋值函数
return 0 ;
}
(1) 普通构造函数:这里判断了传入的参数是否为NULL。如果是NULL,初始化一个字节的空字符串(包括结束符'\0');如果不是,分配足够大小长度的堆内存来保存字符串。
(2)复制构造函数:只是分配足够小长度的堆内存来保存字符串。
(3)析构函数:如果类私有成员m_String不为NULL,释放m_String指向的堆内存,并且为了避免产生野指针,将m_String赋为NULL ;
(4)赋值函数:首先判断当前对象与引用传递对象是否是同一个对象,如果是,不作操作,直接返回;否则,先释放当前对象的堆内存,然后分配足够大小长度的堆内存复制字符串。
程序的执行结果如下:
1 Constructing
2 Constructing
3 Constructing Copyion
4 Operate = Function
5 Destructing
6 Destructing
7 Destructing
这里的代码第63~66行会发生构造函数以及赋值函数的调用,而析构函数的调用发生在main()函数退出时。