C++类构造函数和析构函数,拷贝构造函数,this指针
构造函数名称和类名称相同,构造函数为类的对象提供初始化功能。每当创建新类时都会调用构造函数。构造函数可以有多个。
构造函数定义
构造函数与普通成员函数区别:不含有返回类型。如:
student::student(double w,double h);//student前什么都没有
void student::show();//有void
构造函数参数列表含有一个或多个需要初始化的数据成员.注意构造函数的参数不是类私有数据成员,而是新的变量
student::student(double w, double h)//此处不是weight和height { weight=w; height=h; } |
使用构造函数实例化一个对象(显式和隐式)
student A=student(45,100);//显示创建对象A,A的体重45kg,身高100cm
student A(45,100);//隐式创建对象
默认构造函数:
用以下方式创建对象时会调用默认构造函数,如
student C;//C后面没有()
没有定义任何构造函数时,编译器会自动创建默认构造函数。程序员一旦为类定义构造函数时也需要提供默认构造函数,否则语句student C会无法通过编译。定义默认构造函数有两种。一种是给已经定义的构造函数参数全部初始化,如
student::student(double w=0,double h=0) { weight=w; height=h; } |
另一种是函数重载方式,定义一个没有参数的构造函数。在这个构造函数中一般会对类数据成员初始化
student::student()
{
weight=0;
height=0;
}
析构函数
析构函数完成清理工作。一般是当对象失效时调用。形式如下:~student();
student::~student()
{
}
每个类都只能有一个析构函数。如果构造函数使用了new,则析构函数得提供delete
拷贝构造函数
对于普通类型的对象他们复制很简单,比如int a=100;int b=a;而类对象内部结构复杂,例子如下
#include<iostream> using namespace std; class CExample { private: int a; public: //构造函数 CExample(int b) { a=b; printf("constructor is called\n"); } //拷贝构造函数 CExample(const CExample & c) { a=c.a; printf("copy constructor is called\n"); } //析构函数 ~CExample() { cout<<"destructor is called\n"; } void Show() { cout<<a<<endl; } }; int main() { CExample A(100); CExample B=A; B.Show(); return 0; } |
CExample(const CExample& C) 就是我们自定义的拷贝构造函数。可见,拷贝构造函数是一种特殊的构造函数,函数的名称必须和类名称一致,它必须的一个参数是本类型的一个引用变量。
A.类的对象作为实参传递给一个非引用类型的形参。此时需要使用拷贝构造函数将对象的值传给形参,比如
Function(student s)
{
}这时候s被拷贝初始化,在函数function执行完毕后被析构
B.从一个返回类型为非引用类型的函数返回一个对象时
student function(student & s)
{student t;
return t;
}
c. 用一个对象初始化另一个对象时
Time A(10,10); Time B(A)
This指针
很多时候类成员函数需要对两个对象进行操作,比如比较两个对象。如下:
sudent:: com(student & s) { Double w1=s.weight; double w2=weight; if (w1>w2) { Return s; Else Return ???} |
为了解决这个问题。C++使用this指针指向当前对象。那么上面可以补充为
return *this
reference: https://blog.csdn.net/u013921430/article/details/79868875