栈内存申请与堆内存申请

栈申请与堆申请

#include "stdafx.h"
#include <stdlib.h>

int _tmain(int argc, _TCHAR* argv[])
{
#if 0
	//栈申请
	int a;   int *pa = &a;
	*pa = 100;
	printf("a = %d\n", a);

	//堆申请
	int *p = (int *)malloc(sizeof(int));
	*p = 200;
	printf("*p = %d\n", *p);
	free(p);

	//int a[1024*1024];
	//int * p = (int*)malloc(1024*1024*1024);
	//if(p == NULL)  //通过返回值来进行判断是否成功申请
	//{
	//    printf("malloc error\n");
	//}

	int array[100]; int *pa = array; //栈

	int *p = (int*)malloc(sizeof(int)*100); //堆
	for(int i=0; i<100; i++)
	{
	    p[i] = 100;
	    printf("%d\n",p[i]);
	}
	free(p);
#endif
	//calloc(对malloc的包装)适合申请数组
	int *p = (int*)calloc(100, sizeof(int));

	for (int i = 0; i<100; i++)
	{
		//自动给初始化为0
		printf("%d\n", p[i]);
	}
	free(p);

	//realloc 用于扩容原有内存的大小
	//返回的地址有可能和原来的地址不相同
	//因为原地址后面空间大小如果不够,需要另开辟一处空间
	//来存储原有数据和扩容数据,返回的地址为新地址

	return 0;
}






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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值