malloc 和 calloc
malloc
函数原型: extern void *malloc(unsigned int num_bytes);
函数描述: 分配长度为num_bytes字节的内存块
入口参数: num_bytes 内存块的大小(单位为字节)
出口参数: 无(或为空)
返回值: 如果分配成功则返回指向被分配内存的指针,否则返回空指针NULL。
函数说明 不再使用时一定要记得释放,调用函数free
函数说明 不再使用时一定要记得释放,调用函数free
使用示例:
char *pTemp = NULL;
pTemp = (char *)malloc(10 * sizeof(char));
个人理解:
[1]申请空间大小时,利用sizeof做出计算,这样保证会分配正确数量的内存空间;
[2]malloc返回的内存是没有被初始化的,所以可能包含着任何的随机垃圾,应该在其后马上调用memset函数进行初始化为0的操作;
calloc
函数原型: void *calloc(size_t nelem, size_t elsize);
函数描述: 分配指定长度的内存空间
入口参数: nelem 元素的个数(如为10个char申请空间,则为10)
elsize 元素所占用的字节(如为char申请,则为sizeof(char))
出口参数: 无(或为空)
返回值: 如果分配成功则返回指向被分配内存的指针,否则返回空指针NULL。
函数说明 不再使用时一定要记得释放,调用函数free
函数说明 不再使用时一定要记得释放,调用函数free
使用示例:
char *str = NULL;
str = calloc(10, sizeof(char));
个人理解:
[1]calloc实际上也只能算作是malloc的一种简单的封装;
[2]它会自动的把动态分配的内存进行清0操作,并且保证了分配数量的正确,所以建议使用。
其他说明:
进程对动态内存的分配请求被认为是不紧迫的。例如,当进程的可执行文件被装入时,进程并不一定立即对所有的代码进行访问。
类似地,当进程调用malloc() 请求动态内存时,并不意味着进程很快就会访问所有获得的内存。
因此一般来说,内核总是尽量推迟给用户态进程动态分配内存。
这里只是简单的做个说明……