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

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

相关推荐
ZPC82103 分钟前
ROS 2 手眼标定完整方案
人工智能·算法·性能优化·机器人
Q741_14716 分钟前
每日一题 力扣 3418. 机器人可以获得的最大金币数 力扣 215. 数组中的第K个最大元素 动态规划 TopK问题 C++ 题解
c++·算法·leetcode·动态规划·topk
Frostnova丶22 分钟前
LeetCode 3418.机器人可以获得的最大金币数
算法·leetcode
寻寻觅觅☆25 分钟前
东华OJ-基础题-31-素数(C++)
开发语言·c++·算法
仟濹30 分钟前
【算法打卡day36(2026-04-02 周四)】DFS专项训练3
算法·深度优先
B1acktion33 分钟前
2.3.插入排序——像打牌一样整理数组,为什么它对“几乎有序”数据特别友好?
数据结构·算法·排序算法
Mr_Xuhhh36 分钟前
C++算法刷题:排序子序列、削减整数、最长上升子序列(二)题解
开发语言·c++·算法
tankeven38 分钟前
HJ157 剪纸游戏
c++·算法
迈巴赫车主41 分钟前
蓝桥杯 19717 挖矿java
java·开发语言·数据结构·算法·职场和发展·蓝桥杯
airuike1231 小时前
高性能MEMS IMU:机器人自主运动的核心感知中枢
人工智能·算法·机器人