堆栈与动态分配内存空间

        在开发过程中,我们往往是没办法一开始就决定好存储空间的,除非把存储空间开辟得足够大,但这不切实际。所以我们经常会遇到需要动态分配存储空间的时候,既然常用,那我便记录一下C/C++的动态分配内存空间。打算以常用的动态分配数组为例说明。不过在说明之前,还是先搞清我们程序的内存是在哪儿分配的。简要说明如下:

        程序代码——存放在代码区;

        全局变量、static变量——存放在静态存储区(全局区);

        常量——存放在常量区;

        局部变量、函数形参——存放在栈上;

        程序员自己分配的——存放在堆上;

        更多堆栈内容可以查看这位大神的博客(链接)讲解很全面。

        另外,C语言中内在分布及程序运行中的BSS段、数据段、代码段、堆和栈的概念详情可见这位大神的博客(链接)。

        下面进行动态数组分配,先写C语言,C语言动态内存分配/释放数组,主要依靠malloc、free函数,成对出现,不然容易堆溢出,头文件<malloc.h>

//C语言动态内存分配/释放数组,主要依靠malloc、free函数,成对出现,不然容易堆溢出,头文件<malloc.h>

#include <stdio.h>
#include <malloc.h>

int main()
{
	int n,i;
	printf("请输入数组大小:\t");
	scanf("%d",&n);
	int *p=(int *)malloc(n*sizeof(int));//在空闲内在池中分配连续内存n*sizeof(int)个字节的堆内存空间
	if(p!=NULL)
	{
		printf("数组大小为%d,内存申请成功,下面对数组赋值并输出\n",n);
		for(i=0;i<n;i++)
		{
			*(p+i)=i;
			printf("%d\t",*(p+i));
		}
		free(p);
	}
	else
	{
		printf("内存分配失败\n");
	}
	return 0;

}

下面是C++内存分配:

//C++动态内存分配/释放,主要依靠new、delete运算符,必须成对出现

#include <iostream>
using namespace std;

int main()
{
	int n,i;
	int *p;
	cout<<"请输入数组大小:\t"<<endl;
	cin>>n;
	p = new int[n];
	if(p!=NULL)
	{
		cout<<"申请内存成功,数组大小为"<<n<<endl;
		for(i=0;i<n;i++)
		{
			*(p+i)=i;
			cout<<*(p+i)<<endl;
		}
	}
	else
	{
		cout<<"申请内存失败!"<<endl;
	}
	delete []p;
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值