malloc 函数实现

2014-12-24 09:30:09 +08:00
 ivito
见到网上一片文章用系统调用sbrk实现malloc。
http://blog.jobbole.com/82511/
sbrk(0)会返回指向当前堆顶部的指针。sbrk(foo)会增加foo字节的堆空间并返回指向当前堆顶部的指针。
#include <assert.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>

void *malloc(size_t size) {
void *p = sbrk(0);
void *request = sbrk(size);
if (request == (void*) -1) {
return NULL; // sbrk failed
} else {
assert(p == request); // Not thread safe.
return p;
}
}
但是if语句中的 (void*)-1 是什么意思呢
2769 次点击
所在节点    程序员
6 条回复
carmark
2014-12-24 09:44:57 +08:00
sbrk函数调用成功返回一指针,指向下一个内存空间。函数调用失败则返回(void*)-1,将errno设为ENOMEM。

查查sbrk的manpage就能看到了。
semicircle21
2014-12-24 09:47:51 +08:00
就是判断 sbrk 返回的是不是-1, 加了个类型转换而已,
眼花了?
ivito
2014-12-24 09:48:33 +08:00
@carmark 已找到,感谢
On success, brk() returns zero. On error, -1 is returned, and errno is set to ENOMEM. (But see Linux Notes below.)
ivito
2014-12-24 09:49:26 +08:00
@semicircle21 一时没想过来,之前没见过用负数表示地址的
icenan2
2014-12-24 09:49:40 +08:00
-1 转换成(void*)应该就是地址的最大值吧
ivito
2014-12-24 10:09:30 +08:00
@icenan2 对,全f

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/156196

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX