unix高级环境编程笔记--内存分配调用与堆栈空间

#include <stdlib.h>
void *malloc(size_t size); 分配size个字节的空间
void *calloc(size_t nobj, size_t size); 分配nobj个size字节的连续空间
void *realloc(void *ptr, size_t newsize); 分配以ptr为起始地址的size个字节的连续空间(若ptr为null,则功能与malloc相同)

以上三个函数若成功则返回所分配空间的起始地址,否则返回null。
void free(void *ptr); 释放以ptr为起始地址的分配空间

注意点:
1.上文三个空间分配函数所分配空间位于进程的heap区
2.realloc分配空间,若newsize比ptr所指的空间大,则先尝试在原已分配的空间后补差值,若没有空余的空间则往高地址寻找适合newsize的自由空间,将ptr原有空间的内容复制到新地址,然后释放原有空间。
3.空间分配过程(allocation routines)会自动调用sbrk来扩展进程的堆(heap),大多数系统实现的malloc和free不会减少进程已用的内存,free释放的空间仍保留在malloc池中,用于之后的内存分配
4.分配空间除了实际分配的大小外,还有一部分用于记录所分配空间的大小与下一块分配空间的指针。而这部分内容(可称为分配空间块的头)一般记录在所分配空间之前,因此要注意在使用指针对分配空间上的内容进行操作时避免越界,否则将有可能修改了当前分配空间块或下一块空间块的头信息。这种错误比较常见,并且需要一段时间才会诱发问题。
5.另外可能出现的错误是释放一个已经释放过的空间块,或者调用free来释放本不是由上文三个空间分配函数获得的空间。一般来说malloc分配空间后若该空间不再使用时要在适当的时候调用free释放,否则有更多的malloc调用使得进程占用的内存增多,造成内存泄漏。


alloca函数
这个函数与上文三个空间分配函数不同,它所分配的空间是在进程的栈区,而不是在堆区,其优点在于我们不用去手动释放掉这些空间,当函数返回时这些空间会被自动释放。alloca调用会增长栈区的大小,因此在无法通过调用alloca自动增加栈大小的系统不支持alloca函数。目前有许多系统支持这个功能


另外关于堆栈空间的参考
http://www.cppblog.com/oosky/archive/2006/01/21/2958.html

你可能感兴趣的:(编程,unix)