class String
{
public:
//普通构造函数
String( const char *str = NULL );
//拷贝构造函数
String( const String &other );
//析构函数
~String( void );
//赋值函数
String & operate =( const String &other );
private:
//用于保存字符串
char *m_data;
};
String::~String(void)
{
delete []m_data;
//由于m_data是内部数据类型,也可以写成delete m_data;
}
String::String(const char* str)
{
if( str == NULL )
{
m_data = new char[1];//若能加NULL判断则更好
*m_data = '\0';
}
else
{
int length = strlen(str);
m_data = new char[ length + 1 ];
strcpy(m_data, str);
}
}
String::String(const String &other)
{
int length = strlen(other.m_data);
//若能加NULL判断则更好
m_data = new char[ length + 1 ];
strcpy(m_data, other.m_data);
}
String & String::operate =(const String &other)
{
//检查自赋值
if( this == &other )
return *this;
//释放原有的内存资源
delete []m_data;
//分配新的内存资源,并复制内容
int length = strlen( other.m_data );
m_data = new char[ length + 1 ];
strcpy( m_data, other.m_data );
//返回本对象的引用
return *this;
}
const有两个作用 1.const变量不能随意转化成非const变量
{
public:
//普通构造函数
String( const char *str = NULL );
//拷贝构造函数
String( const String &other );
//析构函数
~String( void );
//赋值函数
String & operate =( const String &other );
private:
//用于保存字符串
char *m_data;
};
String::~String(void)
{
delete []m_data;
//由于m_data是内部数据类型,也可以写成delete m_data;
}
String::String(const char* str)
{
if( str == NULL )
{
m_data = new char[1];//若能加NULL判断则更好
*m_data = '\0';
}
else
{
int length = strlen(str);
m_data = new char[ length + 1 ];
strcpy(m_data, str);
}
}
String::String(const String &other)
{
int length = strlen(other.m_data);
//若能加NULL判断则更好
m_data = new char[ length + 1 ];
strcpy(m_data, other.m_data);
}
String & String::operate =(const String &other)
{
//检查自赋值
if( this == &other )
return *this;
//释放原有的内存资源
delete []m_data;
//分配新的内存资源,并复制内容
int length = strlen( other.m_data );
m_data = new char[ length + 1 ];
strcpy( m_data, other.m_data );
//返回本对象的引用
return *this;
}
const有两个作用 1.const变量不能随意转化成非const变量
2.用"+"赋值必须返回一个操作值已知的MyString对象,除非它是一个const对象
加油!