free在释放内存的时候,为什么不需要指定内存的大小?
这个是学生前两天面大疆的时候,面试官提出的问题。
这个问题不难,比起malloc申请内存的过程要简单的多。
malloc在申请内存的时候,需要指定内存的大小,申请成功则返回这块内存的地址,但是free的时候,只需要指定释放的内存的起始地址,系统就知道从这个地址开始需要释放多少个字节。
char*ptr = (char *)malloc(128); free(ptr);原因也很简单,malloc在申请内存的时候,申请到的内存往往比我们需要的内存大,也就是在我们能使用的内存前面会多出一块内存存放头部 信息,这个信息就包含了接下来这块内存的大小。
所以在释放内存的时候,只要根据我们提供的地址,向前再移动一些字节,就能知道需要释放的内存大小。
《unix环境高级 编程》一书中也提到:
大多数实现所分配的存储空间比所要求的要稍大一些,额外的空间用来记录管理信息——分配块的长度,指向下一个分配块的指针等等。
当然,这个所谓的头部信息,不同的平台存放的内容也不太一样。
《C程序设计语言》这本书中就提到了一种结构:
union header_t { struct { unsigned size; unionheader_t*next; }; long align; };联合体中嵌套了结构体,结构体中包含了两个成员:一个是指向下一个头部的指针,一个表示堆内存的大小。
写个代码验证一下。
char*ptr=(char*)malloc(128);memset(ptr - 16, 0, 16); free(ptr);先用malloc申请一块内存,然后从返回的地址开始,向前16个字节,全部清空成0,然后再用free释放内存。
编译没有问题,但是运行的时候,提示free出错。 这只是个演示代码,实际情况不一定是16个字节。
所以在写代码的时候,一定不要越界访问,一旦出了问题,很难去定位问题的出处。
审核编辑:刘清
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表德赢Vwin官网 网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。
举报投诉
- C语言
+关注
关注
180文章
7565浏览量
133435
原文标题:free()为什么不需要指定内存大小
文章出处:【微信号:学益得智能硬件,微信公众号:学益得智能硬件】欢迎添加关注!文章转载请注明出处。
发布评论请先登录
相关推荐
Linux内存系统: Linux内存分配算法
, kmem_cache_
free() 在其参数所
指定的高速缓存中
释放一个 slab9、内核态
内存池1) 基本原理· 先申请分配一定数量的、
大小
发表于08-24 07:44
使用malloc()和free()函数动态的分配/释放内存的危害
前言本文会从以下几个方面阐述使用malloc()和
free()函数动态的分配/
释放
内存的危害。存在的问题在嵌入式中无法很难实现对
内存的动态映射(虚拟
发表于12-14 07:56
可以使用malloc()和free()这两个函数动态分配内存和释放内存吗
在ANSI C中,可以使用malloc()和
free()这两个函数动态分配
内存和
释放
内存,但是,
在
发表于12-17 08:26
使用rt_free释放内存时出现tofreea bad data block:的错误是为什么?
最近在使用rt_
free
释放
内存时会出现to
freea bad data block:的错误。期初怀疑重复
释放
发表于03-17 09:24
请教内存的释放是否是在rt_free后就完成呢
问题描述:1.在线程中调用了一个函数A,该函数会申请
内存函数结束前会再
释放。测试中发现这个函数在线程中调用几次后就提示异常,申请不到
内存。2:请教:
内存的
发表于08-29 11:41
LINUX内核中的内存是如何进行分配的
size);size:待分配的
内存的
大小,自动按页对齐。默认
在动态
内存映射区分配。分配的
内存在内核空间中连续(虚拟连续),物理上无需连续。
发表于11-04 14:46
基于SLUB的DEBUG功能,如何帮忙检测内存越界和访问已经释放的内存
SLAB
内存分配器-SLUB的DEBUG功能,如何帮忙检测
内存越界(out-of-bounds)和访问已经
释放的
内存(use-after-
free
STM32内存管理
内存管理详解1、介绍
内存管理,是指软件运行时对计算机
内存资源的分配和使用的技术。其最主要的目的是如何高效,快速的分配,并且
在适当的
时候
发表于12-24 19:37
•
13次下载
realloc函数和free函数的实验及注意事项
拷贝到新分配的
内存区域,而后
释放原来 mem_address 所指
内存区域(注意:原来指针是自动
释放,
不需要使用
内存释放free步骤
内存
释放
freePublic_
fREe() void public_
fREe(Void_t* mem) { mstate ar_ptr;
评论