malloc的内存分配之 malloc(0)的内存分配情况

本文通过一个简单的C++示例程序探讨了malloc函数的行为特点,特别是当请求分配0字节内存时的情况。文章解释了malloc如何处理这种情况并揭示了其内部最小分配单位的概念。此外,还讨论了new和malloc等内存分配函数如何跟踪分配的内存大小。
摘要由CSDN通过智能技术生成

#include<iostream>

using namespace std;

int main()

{

       char *p;

       if((p=(char *)malloc(0))==NULL)

              puts("got a null pointer");

       else

              puts("got a valid pointer");

 

}

答案:got a valid pointer

 

 

首先: 
    在标准的malloc实现中,并不检查输入值的大小,而是将输入值做对齐操作后直接从堆上分配空间。 
其次: 
    不论输入值的大小为多少,在malloc的内部最小的内存分配大小是一个定值(一般是8B),因为malloc需要用这部分空间来维护堆上的内存块链表。所以当用户申请一块0B的空间时,malloc实际分配的空间是8B,如果用户申请的空间是X,则malloc实际分配的空间是(对齐(X)   +   8)。这也是为什么malloc分配的空间千万不能越界使用的原因:堆的内部链表结构将被破坏。

 

 

另外对于new和delete malloc和free这样的内存分配与释放函数:到底delete和free是怎么知道要释放掉多少内存的呢?

其实在new和malloc内存分配成功时,系统出除了返回一个指向这块内存的指针外,还会获得一块用于记录此处分配的内存大小的内存块:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值