动态分配内存函数——calloc,free,malloc,realloc

头文件:#include “stdlib.h”
void*calloc(size_t num,size_t size);

功能:num是请求分配的单元个数,size是每个单元的大小,如果成功则返回一个内存指针,指向一块内存,并且和malloc不同的是:这块内存已经被清零了!失败返回NULL。

例子:int *p=(int *)calloc(4,sizeof(int));

    请求分配4个int大小的清零了的内存空间,相当于使用了

    int *p=malloc(sizeof(int)*4);

    memset(p,0,sizeof(int)*4);

void *malloc(size_t num);

功能:num是请求分配的内存字节数,成功则返回一个指向内存的指针,否则返回NULL。

例子:如上。

void *realloc(void *old, size_t new_size);

功能:old是原来分配的内存地址指针,new_size是请求分配的内存的新的大小,可以比原来小(但是对于数据来说不安全),也可以比原来的大。realloc会将原来内存中的内容复制到新的内存区域,然后返回新的内存指针,失败返回NULL。

例子:p=(int *)realloc(p,4*2); //将前面分配的内存扩大两倍

void *alloca(size_t size);

功能:size是请求分配的内存大小(字节),alloca函数和前面的函数都不同,前面的函数在进程的堆空间中分配内存,所以需要手动free,而alloca函数在进程的栈空间中分配内存,所以当调用alloca函数的函数执行结束时,alloca分配的内存也就自动释放。

来自博客:http://blog.csdn.net/leisure512/article/details/4788467

同样的有百度上面的解释:
1函数名称: calloc
函数原型: void * calloc(unsigned n,unsign size);
函数功能: 分配n个数据项的内存连续空间,每个数据项的大小为size
函数返回: 分配内存单元的起始地址,如果不成功,返回0
2函数名称: free
函数原型: void free(void* p);
函数功能: 释放p所指的内存区
函数返回:
参数说明: p-被释放的指针
3函数名称: malloc
函数原型: void * malloc(unsigned size);
函数功能: 分配size字节的存储区
函数返回: 所分配的内存区地址,如果内存不够,返回0
4函数名称: realloc
函数原型: void * realloc(void * p,unsigned size);
函数功能: 将p所指出的已分配内存区的大小改为size,size可以比原来分配的空间大或小
函数返回: 返回指向该内存区的指针.NULL-分配失败

你可能感兴趣的:(函数,内存,malloc,sizeof,指针)