静态存储类成员
- 无论创建了多少对象,程序都只创建一个静态类变量副本。
- 不能再类声明中初始化静态成员变量。(声明描述了如何分配内存,但并不分配内存)
注意:静态数据成员在类声明中声明,在包含类方法的文件中初始化。初始化时使用作用域运算符来指出静态成员所属的类。但如果静态成员是整数或枚举性const
,则可以在类声明中初始化。
特殊的成员函数
C++自动提供下面成员函数的定义:
- 默认构造函数,如果没有定义构造函数
- 默认析构函数,如果函数没有定义析构函数
- 默认复制构造函数,如果没有定义
- 赋值运算符,如果没有定义
- 地址运算符,如果没有定义
C++11还提供了两个特殊的成员函数,移动构造函数(move constructor)和移动赋值运算符(move assignment operator)
复制构造函数
何时调用:每当程序生成了对象副本时,编译器都将使用复制构造函数。具体的说,当函数按值传递对象或函数返回对象时,都将使用复制构造函数。记住,按值传递意味着创建原始变量的一个副本。编译器生成临时对象时,也将使用复制构造函数。
有何功能:默认的复制构造函数逐个复制非静态成员变量(这就是所谓的浅复制),复制的是成员的值。要对静态成员变量(指针变量也是同样)进行复制,则必须提供自定义的复制构造函数对静态成员变量提供赋值操作(这就是深度复制)
赋值运算符
将已有的对象赋给另一个对象时,将进行赋值运算符;默认的赋值运算符也是浅复制,要想进行深度赋值,则可以通过进行重载赋值运算符
总结
- 应当定义一个复制构造函数,通过深度复制讲一个对象初始化为另一个对象。类似下面的构造函数。
String::String(const String & st){
num_string++; //handle static member update if necessary
len = st.len; //same length as copied string
str = new char[len + 1]; //allot space
std::strcpy(str,st); //copy string to new location
}
- 应该定义一个赋值运算符,通过深度复制将一个对象复制给另一个对象。类似下面的赋值运算符。
String & String::operator=(const String & st){
if(this == &st) //object assigned to itself
return *this; //all done
delete []str; //free old string
len = st.len;
str = new char[len + 1]; //get space for new string
std::strcpy(str,st); //copy the string
return *this; //return reference to invoking objece
}