C语言malloc和free

本文通过实例介绍了C语言中malloc函数的使用,该函数用于根据需要从堆中分配内存,并返回内存起始地址。malloc分配的内存块是匿名的,不指定具体名称。同时,文章提到了malloc操作的内存区域——堆,并预告了后续会讨论堆和栈的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 通过一个简单的例子说明
  • malloc就一个参数,所需内存字节数。malloc会找到可用内存中的一个大小适合的块。内存块是匿名的也就是说malloc分配了内存,但是没有为它指定名字,但是它会返回那块内存第一个字节的地址。
  • 而malloc申请的那块内存是从“堆”申请的,关于堆栈会再写一篇博文说明下,这篇讲的也不错
#include<stdio.h>
#include<stdlib.h>

typedef unsigned char unint8;

void main()
{
	
	unint8 *ret=NULL;
	unint8 *addr=0;
	ret = (unint8 *)malloc(100*sizeof(unint8));
	/*
		malloc 向内存申请了100个char类型值的内存空间,并返回了这块内存块第一个字节的地址,把ret指向该空间所在位置
		Note:ret是作为指向一个unint8类型值的指针声明的,而不是指向100个unint8类型值的数据块的指针,所以令ret指向一个内存块的第一个元素,
		就可以像使用数组一样使用了
	*/
	if(ret==NULL)
	{
		printf("Memroy allocation failed.\n\n");
	}
	else
	{
		/*
		上面的malloc可以当作申请了一个100大小的unint类型的数组,数组第一个元素的指针是ret
		ret[1]==*(ret+1),指针+1增加1个unint类型值大小
		*/
		*(ret+1)=10;
		printf("buf[1]=%d\taddr:%p\n",ret[1],&ret[1]);
		/*
		将ret[1]地址0x2268011重新赋值给另一个指针,并+1
		*/
		addr=&ret[1];
		*(addr+1)=20;
		printf("buf[2]=%d\taddr:%p\n",ret[2],&ret[2]);
		
		ret[3]=30;
		printf("buf[3]=%d\taddr:%p\n",ret[3],&ret[3]);
		/*
		malloc和free合作使用
		这时还要注意另一个地方,关于野指针
		ret和addr都已经赋值使用,在free之后仅仅释放了malloc的内存,如果后续再使用了ret和null就可能出问题,因为他们还是指向这段内存,而这段内存可能会被其他程序使用
		俗称野指针,其实就是没有重新赋值成NULL
		*/
		free(ret);
		ret=NULL;
		addr=NULL;
		/*
            buf[1]=10       addr:0x2268011
            buf[2]=20       addr:0x2268012
            buf[3]=30       addr:0x2268013

			*/
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值