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

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

相关推荐
To_OC11 小时前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安16 小时前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者18 小时前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent
kisshyshy1 天前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范
To_OC1 天前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户938515635072 天前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC2 天前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥2 天前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程