//创建字符串:
String s1(),
String s2("hello");
//拷贝构造
String s3(s1);
cout << s3<< endl;
//拷贝赋值
s3=s2;
cout<<s3<<endl;
一般而言对于字符串的设计:让字符串拥有一个指针,在需要内存的时候,才创建另外一个空间创建去存放字符。因为字符串有大有小 ,所以这才给了动态的感觉。
data 是一个指针,指向字符 :char* m_data
Big String
class String
{
public:
String(const char* cstr=0); //存进来一个指针,默认为0
String(const String& str); //拷贝构造,它接收到的是它自己这种东西
String& operator=(const String& str);
//操作符重载,:右边赋值也是它这种东西,这一步就拷贝赋值
~String ();//析构函数 什么时候会死亡?就是离开了它的作用域的时候。
//所以以上就是拷贝和赋值的写法。
//只要类带着指针,就要有这两种写法。
char* get_c_str() const { return m_data ;}//传回来的是一个指针,一般的成员函数:并没有改变data。因为不改变data 所以要加const .这也是一个内联函数。
}
private:
char* m_data; // m_data是一个指针,这就是传回去的指针
============
vtor 和 dtor 构造函数和析构函数
inline
String::String (const char* cstr=0)
//C/C+ 长度或者有结束符号。 面对字符串,要想到最后的结束符号,
这是个构造函数
{
if (cstr){
m_data = new char[strlen (cstr)+1]; //传进来的这个长度 +1 就是\0 这个结束符号
strcpy(m_data,cstr); //传进来的拷贝至新分配的地方
}
else{
m_data= new char[1];
*m_data ='\0';
}
}
inline
String::~String() //析构函数,因为是脱离class本体,所以要就加全名
{
delete[] m_data; //动态分配的内存,所以要清0,防止内存泄露
}
{
String s1();
String s2("hello"); //字符串其实本质就是指针
String* p =new String ("hello"); //动态创建字符串
delete p;
}
总结:class中有指针,多半要动态分配。析构函数,动态分配到的内存要去释放内存