实现一个类,计算程序中创建出了多少个对象

假设命名该类为A,那么A类型的对象一定是经过构造函数或拷贝构造的,那么我们就可以分别定义两个静态成员变量,在构造函数和拷贝构造里++变量,这样,每创建一次对象,变量就++一次,自然就好求了。如下:

cpp 复制代码
class A
{
public:
	A()
	{
		++_count1;
	}
	A(const A& aa)
	{
		++_count2;
	}
	static int GetCount1()
	{
		return _count1;
	}
	static int GetCount2()
	{
		return _count2;
	}
private:
	static int _count1;
	static int _count2;
};

int A::_count1 = 0;
int A::_count2 = 0;

A Func(A a)
{
	A copy(a);//1
	return copy;//2
}
int main()
{
	A a1;
	A a2=Func(a1);//3

	cout << a1.GetCount1() << endl;//1
	cout << a2.GetCount2() << endl;//3
	cout << A::GetCount1() + A::GetCount2() << endl;//4
}

这里用全局变量(count1和count2)也是可以的,但不推荐。在简单的程序里可以使用没问题,但是在项目中不推荐用全局的,因为可能会出现链接冲突的问题,还是用静态成员变量为优。

相关推荐
程序员小明儿6 分钟前
量子计算探秘:从零开始的量子编程与算法之旅 · 第四篇
算法·量子计算
程序员小明儿9 分钟前
量子计算探秘:从零开始的量子编程与算法之旅 · 第一篇
算法·量子计算
不想看见40410 分钟前
Add Strings数字处理--力扣101算法题解笔记
数据结构·算法·leetcode
云泽80813 分钟前
C++ STL set 容器全解析:从基础用法、算法实践到云同步实战
开发语言·c++·算法
absunique29 分钟前
复杂度分析中的常数优化与性能重构的技术6
算法·重构
初次攀爬者32 分钟前
力扣解题-74. 搜索二维矩阵
算法·leetcode
xiaoye-duck38 分钟前
《算法题讲解指南:优选算法-分治-快排》--45.数组中的第k个最大元素,46.最小的k个数
c++·算法
Galerkin码农选手44 分钟前
per_tenor_quant_fp8和per_token_quant_fp8算法解读
人工智能·pytorch·算法
tankeven44 分钟前
HJ125 最大最小路
c++·算法
MegaDataFlowers1 小时前
认识复杂度和简单排序算法
java·算法·排序算法