手拿把掐:类对象在进行函数传参及返回临时对象时调用过程分析

#include <iostream>
using namespace std;
class Person
{
public:
	Person() 
	{
		std::cout << "Person()" << std::endl;
	}
	virtual ~Person() 
	{
		std::cout << "~Person()" << std::endl;
	}
	Person(const Person& p)
	{
		this->name_ = p.name_;
		this->sex_ = p.sex_;
		std::cout << "Person copy construct()" << std::endl;
	}
private:
	string name_;
	string sex_;
};
class Student : public Person
{
public:
	Student()
	{
		std::cout << "Student()" << ",this :"<< this << std::endl;
	}
	~Student()
	{
		std::cout << "~Student()" << ",this :" << this << std::endl;
	}
	Student(const Student& s): Person(s)
	{
		std::cout << "copy construct" << ",this :" << this << std::endl;
		this->student_name_ = s.student_name_;
		this->student_sex_ = s.student_sex_;
	}
private:
	string student_name_;
	string student_sex_;
};
Student Test()
{
	Student s;
	return s;
}
void Test1(Student s)
{
	return;
}
Student Test2(Student s)
{
	return s;
}
/*
针对函数传参,及函数返回对象,有以下结论
传入参数的时候,会调用一次该类的拷贝构造函数,如果该类为子类,还会调用父类的拷贝构造函数
当该函数作用域结束时,调用该类的析构函数和其父类的析构函数。
当返回一个临时对象时,也会调用一次该类的拷贝构造函数,和其父类的拷贝构造函数
当上层作用域结束的时候,临时对象调用该类的析构函数和其父类的析构函数
*/
int main()
{
	/*Student s1 = Test();
	std::cout << "===============================" << std::endl;*/
	Student s;
	/*Test1(s);
	std::cout << "===============================" << std::endl;*/
	Student s1 = Test2(s);
	std::cout << "===============================" << std::endl;
	return 0;
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值