6-4 局部静态对象、对象数组构造析构和内存分配


#include "pch.h"
#include <iostream>
#include <vector>
#include <ctime>
#include<algorithm>

using namespace std;

namespace _nmsp1
{	
	//一:局部静态对象的构造和析构
	//a)如果我们不调用myfunc()函数,那么根本不会触发A的构造函数;
	//b)局部静态对象,内存地址是在编译期间就确定好的;
	//c)静态局部量刚开始也被初始化为0;
	//d)局部静态对象的析构,是在main函数执行结束后才被调用的。(前提是这个静态局部对象被构造过)

	//局部静态对象只会被构造一次,在调用的时候构造;在main函数执行完毕后析构

	class A
	{
	public:
		A()
		{
			cout << "A::A()" << endl;
		}
		~A()
		{
			cout << "A::~A()" << endl;
		}
		int m_i;
	};

	//void myfunc()
	const A &myfunc()
	{
		//局部静态对象
		static A s_aobj1; //不管myfunc()函数被调用几次,s_aobj1这种静态局部对象只会被构造1次(只调用一次构造函数)
		//static A s_aobj2;
		printf("s_aobj1的地址是%p\n", &s_aobj1);
		//printf("s_aobj2的地址是%p\n", &s_aobj2);
		return s_aobj1;
	}

	void func()
	{	
		myfunc();
		myfunc();
	}
}
namespace _nmsp2
{
	//二:局部静态对象数组的内存分配

	class A
	{
	public:
		A()
		{
			//cout << "A::A()" << endl;
		}
		~A()
		{
			//cout << "A::~A()" << endl;
		}
		int m_i;
	};

	void myfunc()
	{
		static A s_aobj[1000'0000]; //理论上应该调用10000000次A构造函数,数组内存应该是连续的
		//for (int i = 0; i < 10000000; i++) //让编译器的分配内存优化能力失效
		//{
		//	s_aobj[i].m_i = i;
		//}
		printf("s_aobj数组的首地址是%p\n", s_aobj);

	}

	void func()
	{
		myfunc();
		myfunc();
	}
}

int main()
{	
	//_nmsp1::func();	
	_nmsp2::func();

	while (1)
	{

	}

	return 1;
}




在这里插入图片描述

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值