标签:const 特殊 一个 strlen code 不可 == 成员方法 name
class Person{ public : Person():age(10), name(NULL); Person(int myage, char *myname); Person(const Person &a); ~Person(void); void set_age(int myage); void get_age(void); void set_other_age(Person &a, int b); private: int age; char name; }; Person::Person():age(10), name(NULL) { //nothing } Person::Person(int myage, char *myname) { this.age = myage; name = new char[strlen(myname) + 1]; strcpy(name, myname); cout<<"construct!"<<endl; } Person::Person(const Person &a) { cout <<"copy constructor!"<<endl; name = new char[strlen(a.name)+1]; strcpy(name, a.name); age = a.age; } Person::~Person() { delete [] name; cout<<"destructor.!"<<endl; } void Person::set_age(int myage) { this.age = myage; } int Person::get_age(void) { return age; } void Person::set_other_age(Person& a, int b) { a.age = b; //a.set_age(b); }
构造函数、析构函数和赋值函数是类最重要的函数,被称为The Big Three。
与其他成员函数相比,The big three特殊之处在于,如果代码中没有提供这些函数的实现,C++编译器自动合成缺省的函数实现。
有指针成员变量的类一定要提供The Big Three的实现,即使没有指针变量,作为良好的编程习惯也应该提供The Big Three的实现。
和类同名,无返回值,用来初始化类的对象。
构造函数可重载。
编译器提供默认无参构造函数,若声明新的,则采用新的构造函数。一般多应创建一个无参的构造函数,因为创建了有参构造函数后,默认的无参构造函数被覆盖。
构造函数在对象创建后马上调用。
Person a; //调用无参构造函数
Person a(20, "Xiaoming"); //调用两参构造函数
Person(int age=0, const char *name = NULL);构造函数,相当于创建无参或两参构造函数。
Person(const Person &a);
如果没有提供拷贝构造函数,编译器会默认提供一个(执行逐个成员初始化,将新对象初始化为原对象的副本,这里的逐个是指编译器将现有对象的每个非static成员,依次复制到正在创建的对象)。
如果类有指针成员变量,默认构造函数并不会自动分配指针所指向的空间(默认构造函数仅提供浅拷贝),需要添加拷贝构造函数实现深拷贝。
默认拷贝构造函数实现浅拷贝:指针成员变量指向同一存储区域,而不是重新分配区域再赋值(深拷贝)。
析构函数不可重载。
类名前加~的函数,无参数,无返回值。
先调用析构函数->后销毁对象。
默认的析构函数不会释放指针成员变量分配的内存区域,可能造成内存泄露。有指针成员变量时必须实现析构函数。
Person b=a; //拷贝构造函数
Person b;
b = a; //赋值函数 operator=
const变量必须用初始化列表进行初始化。
Person():age(10), name(NULL)中":age(10),name(NULL)"为初始化列表。
每个成员方法都包含一个隐藏参数this,this是一个对象的指针,指向调用函数的对象。
判断自赋值:
if(this == &a){ return *this; }
CPP_类默认函数:构造函数,拷贝构造函数,赋值函数和析构函数
标签:const 特殊 一个 strlen code 不可 == 成员方法 name
原文地址:https://www.cnblogs.com/embedded-linux/p/9613271.html