#include<iostream>
using namespace std;
#include<string>class Person {public:Person() {cout << "Person的无参构造函数调用" << endl;};Person(int age) {m_Age = age;cout << "Person的有参构造函数调用" << endl;};//拷贝构造函数Person(const Person &p) {cout << "Person的拷贝构造函数调用" << endl;//将传入的人身上的所有属性,拷贝到我身上m_Age = p.m_Age;// m_Age = p.m_Age;};~Person() {cout << "Person的析构函数调用" << endl;}int m_Age;};void test() {//1.括号法Person p1; //默认构造函数调用Person p2(10); //有参构造函数Person p3(p2); //拷贝构造函数//2、显示法//3、隐式转换法}//1、使用一个已经创建完毕的对象来初始化- -个新对象
void test01() {Person p1(18);cout << "p1的年龄为:" << p1.m_Age << endl;Person p2(p1);cout << "p2的年龄为:"<< p2.m_Age << endl;};//2、值传递的方式给函数参数传值
void doWork(Person p) {
}
void test02() {Person p;doWork(p);
}int main() {test01();// test01();system("pause");}
深拷贝解决浅拷贝的堆内存重复释放问题
//自己实现拷贝构造函数解决浅拷贝带来的问题Person(const Person &p) { //拷贝构造函数编译器默认实现cout << "Person 拷贝构造函数调用" << endl;m_Age = p.m_Age;// m_Height = p.m_Height; //拷贝构造函数编译器默认实现//深拷贝操作 解决浅拷贝堆内存重复释放m_Height = new int(*p.m_Height);}
#include<iostream>
using namespace std;
#include<string>class Person {public:Person() {cout << "Person的无参构造函数调用" << endl;};Person(int age, int height) {m_Age = age;cout << "Person的有参构造函数调用" << endl;m_Height = new int(height);};/*Person(const Person &p){ //拷贝构造函数编译器默认实现cout << "Person 拷贝构造函数调用"<< endl;m_Age = p.m_Age;m_Height = p.m_Height; //}*///自己实现拷贝构造函数解决浅拷贝带来的问题Person(const Person &p) { //拷贝构造函数编译器默认实现cout << "Person 拷贝构造函数调用" << endl;m_Age = p.m_Age;// m_Height = p.m_Height; //拷贝构造函数编译器默认实现//深拷贝操作 解决浅拷贝堆内存重复释放m_Height = new int(*p.m_Height);}//拷贝构造函数编译器默认实现/*Person(const Person &p) {cout << "Person的拷贝构造函数调用" << endl;//将传入的人身上的所有属性,拷贝到我身上m_Age = p.m_Age;// m_Age = p.m_Age;};
*/~Person() {if (m_Height != NULL) {delete m_Height;m_Height = NULL;}cout << "Person的析构函数调用" << endl;}int m_Age;int *m_Height; //身高
};//1、使用一个已经创建完毕的对象来初始化- -个新对象
void test01() {Person p1(18,160);cout << "p1的年龄为:" << p1.m_Age << "身高为:"<< *p1. m_Height << endl;Person p2(p1);cout << "p2的年龄为:" << p2.m_Age << "身高为:" << *p2.m_Height << endl;};//2、值传递的方式给函数参数传值
void doWork(Person p) {
}
void test02() {Person p;doWork(p);
}int main() {test01();// test01();system("pause");}
总结:如果属性有在堆区开辟的,一定要自己提供拷贝构造函数,防止浅拷贝带来的问题