关于malloc(0)返回值的一些看法

题目来自https://www.jobui.com/mianshiti/it/qianrushi/5829/

以下是原文

下面的代码片段的输出是什么,为什么?

char *ptr;

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

puts(“Got a null pointer”);

else

puts(“Got a valid pointer”);

这是一个有趣的问题。最近在我的一个同事不经意把0值传给了函数malloc,得到了一个合法的指针之后,我才想到这个问题。这就是上面的代码,该代码的输出是“Got a valid pointer”。我用这个来开始讨论这样的一问题,看看被面试者是否想到库例程这样做是正确。得到正确的答案固然重要,但解决问题的方法和你做决定的基本原理更重要些。

其实malloc(0)返回的不是空指针也不足为其,在linux下用man命令查看malloc函数

The  malloc() function allocates size bytes and returns a pointer to the allocated memory.  The memory is not initialized.  If size is 0, then malloc() returns either NULL, or a unique pointer value that can later be successfully passed to free().

说明它确实会有可能申请内存成功的。

malloc申请的内存,一般都会比实质申请的要大,它会去堆空间里面找出一块>=需要申请的内存大小的空闲内存出来,所以malloc里面0值的处理应该是和其他的一样的,就算申请出来,也不会使用它。比如,你申请了一个20字节的空间,malloc返回的是25个字节的空间,你会去使用超出20字节的空间吗?我觉得,malloc开发时就考虑到大家都不会用malloc去申请一个0大小的空间,因为这样没意义,所以也没必要去判断申请的内存大小是否为0了。返回NULL一般是没有足够的空间了,申请空间失败才返回NULL。

发布了21 篇原创文章 · 获赞 5 · 访问量 2257

猜你喜欢

转载自blog.csdn.net/PTA123/article/details/105335417