一. 构造函数与析构函数
1、c++中的类可以定义与类名相同的特殊成员函数,这种函数叫做构造函数。
2、构造函数在定义时可以有参数。
3、没有任何返回类型的声明。
4、一般情况下系统会自动调用,在一些情况下会收手动调用。
构造函数有无参构造,有参构造,(赋值)拷贝构造函数。
#include <iostream>
using namespace std;
class Test
{
public:
Test() // 无参构造函数
{
m_a = 0;
m_b = 0;
cout << "无参构造函数调用" << endl;
}
Test(int a)
{
m_a = 1;
m_b = 2;
cout << "有参构造函数调用1" << endl;
}
Test(int a, int b) // 有参构造函数
{
m_a = a;
m_b = b;
cout << "有参构造函数调用2" << endl;
}
// 赋值构造函数(拷贝构造函数)
Test(const Test &obj)
{
}
public:
void print()
{
cout << m_a << endl;
}
private:
int m_a;
int m_b;
};
int main()
{
//Test t1();
Test t1; // 无参构造函数调用
t1.print();
// 有参构造函数调用
{
//1 括号法
Test t1(1);
t1.print();
Test t2(1,2);
t2.print();
//2 等号法
Test t3 = 5; // 只能进行简单的单个元素赋值
Test t4 = (5,6);
//3 直接调用构造函数
Test t5 = Test(8,9);
t5.print();
}
return 0;
}
1、c++中的类可以定义一个人特殊的成员函数清理对象,这个函数叫做析构函数
语法:~ClassName()
2、析构函数没有任何参数也没有任何返回类型的声明。
3、析构函数在对象被销毁时自动调用。(栈上的空间会自动释放,堆上的空间要手动释放)
二. 对象的初始化与赋值的区别:
Test t1(4,5);
Test t2 = Test(5,6); // 对象的初始化
t2 = t1; // 对象的赋值
三.拷贝构造函数的调用时机:
1、Test t2 = t1; // 用对象 t1 去初始化t2
2、Test t2(t0); // 用对象 t0 去初始化t2
3、PrintObj(t0); // 做函数参数的时候
4、t1 = test(); // 函数返回值返回对象
#include <iostream>
#include <string.h>
using namespace std;
class Test
{
public:
Test() // 无参构造函数
{
m_a = 0;
m_b = 0;
cout << "无参构造函数调用" << endl;
}
Test(int a)
{
m_a = 1;
m_b = 2;
cout << "有参构造函数调用1" << endl;
}
Test(int a, int b) // 有参构造函数
{
m_a = a;
m_b = b;
cout << "有参构造函数调用2" << endl;
}
Test (char *name)
{
strcpy(m_name, name);
}
// 赋值构造函数(拷贝构造函数)
Test(const Test &obj)
{
cout << "拷贝构造函数调用" << endl;
m_a = obj.m_a + 100;
m_b = obj.m_b + 100;
strcpy(m_name, "hello");
}
~Test()
{
cout << "析构函数调用: " << m_name << endl;
}
public:
void print()
{
cout << "m_a:" << m_a << endl;
cout << "m_b:" << m_b << endl;
}
private:
char m_name[20];
int m_a;
int m_b;
};
void PrintObj(Test obj)
{
obj.print();
}
Test test()
{
Test A("name A");
return A;
}
// 赋值构造函数 用一个对象去初始化另一个对象
int main()
{
#if 0
Test t0 = Test(3,4);
Test t1 = Test(5,6);
{
//1 拷贝构造函数调用 1
Test t2 = t1; // 用对象 t1 去初始化t2
t2.print();
}
{
//2 拷贝构造函数调用 2
Test t2(t0); // 用对象 t0 去初始化t2
t2.print();
}
{
//3 类对象当函数形参的时候,实参到形参的转换会调用拷贝构造函数
PrintObj(t0);
}
#endif
{
//4 当函数的返回值是类对象的时候,用一个对象去接收后会调用拷贝构造函数
test();
// 用匿名对象初始化 t, 此时c++编译器直接将匿名对象转化成 t (从匿名转成有名字)
//Test t = test();
Test t1("name t1");
// 用匿名对象给其他对象进行赋值,复制完对象后匿名对象会被析构
t1 = test();
t1.print();
}
return 0;
}
四.两个特殊的构造函数
1)默认无参构造函数
当类中没有定义构造函数时,编译器默认提供一个无参构造函数,并且其函数体为空
2)默认拷贝构造函数
当类中没有定义拷贝构造函数时,编译器默认提供一个默认拷贝构造函数,简单的进行成员变量的值复制
五.拷贝构造函数与析构函数总结:
1)当类中没有定义任何一个构造函数时,c++编译器会提供默认无参构造函数和默认拷贝构造函数
2)当类中定义了拷贝构造函数时,c++编译器不会提供无参数构造函数
3)当类中定义了任意的非拷贝构造函数(即:当类中提供了有参构造函数或无参构造函数),c++编译器不会提供默认无参构造函数
4 )默认拷贝构造函数成员变量简单赋值
总结:只要你写了构造函数,那么你必须用。
构造析构阶段性总结
1)构造函数是C++中用于初始化对象状态的特殊函数
2)构造函数在对象创建时自动被调用
3)构造函数和普通成员函数都遵循重载规则
4)拷贝构造函数是对象正确初始化的重要保证
5)必要的时候,必须手工编写拷贝构造函数