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

假设命名该类为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)也是可以的,但不推荐。在简单的程序里可以使用没问题,但是在项目中不推荐用全局的,因为可能会出现链接冲突的问题,还是用静态成员变量为优。

相关推荐
随缘而动,随遇而安1 小时前
第八十八篇 大数据中的递归算法:从俄罗斯套娃到分布式计算的奇妙之旅
大数据·数据结构·算法
IT古董1 小时前
【第二章:机器学习与神经网络概述】03.类算法理论与实践-(3)决策树分类器
神经网络·算法·机器学习
水木兰亭4 小时前
数据结构之——树及树的存储
数据结构·c++·学习·算法
Jess075 小时前
插入排序的简单介绍
数据结构·算法·排序算法
老一岁5 小时前
选择排序算法详解
数据结构·算法·排序算法
xindafu5 小时前
代码随想录算法训练营第四十二天|动态规划part9
算法·动态规划
xindafu5 小时前
代码随想录算法训练营第四十五天|动态规划part12
算法·动态规划
ysa0510306 小时前
Dijkstra 算法#图论
数据结构·算法·图论
一定要AK7 小时前
2025—暑期训练一
算法
一定要AK7 小时前
贪心专题练习
算法