内存分配函数malloc calloc realloc free
堆内存分配函数 | 说明 |
---|
void * malloc(int n) | 形参n为要求分配的字节数。需要注意的是,malloc函数分配得到的内存空间是未初始化的。必须使用memset函数来初始化。 | calloc(10, sizeof(char)); | 两个参数:单元数,单元的size。分配内存,并清理内存。初始内容全部为0; | realloc(p,10); | 调整内存的大小; 分配的内存空间并未初始化;使用新返回的地址, | free(void * p) | 释放指针p所指向的堆上的空间; |
malloc() 不对分配的内存空间做初始化,内存上原有的值不会被清理。
realloc(),在原有内存基础之上,在堆中间增加连续的内存,如果原有内存没有连续空间可扩展,则新分配一个空间,将原有内存copy到新空间,然后释放原有内存。
p = malloc(10); //直接申请4k的空间。内存页大小。 返回值是无类型指针void *,可以强制转换。
free(p);
char *p = calloc(10, sizeof(char)); //两个参数:单元数,单元的size。 分配内存,并清理内存
char *p2 = realloc(p,10); // 在原有内存基础之上,在堆中间增加连续的内存,如果原有内存没有连续空间可扩展,则新分配一个空间,将原有内存copy到新空间,然后释放原有内存。
char *p2 = realloc(NULL,20); //此时,和malloc等价
realloc和malloc一样,只分配内存,不清理,需要手动初始化。
// 复杂数据内存放在堆里面
内存操作函数 memset memcpy memmove
memset(buf,0,sizeof(buf));
extern void *memset(void *buffer, int c, int count)
memcpy(void *dest,void *src,unsigned int count);
memmove(buf2, buf1, sizeof(buf1));
二维动态数组的建立和释放
在创建动态数组的过程中我们要遵循一个原则,那就是在创建的时候从外层往里层,逐层创建; 而释放的时候从里层往外层,逐层释放。
int main()
{
int num1,num2;
num1 = 4;
num2 = 5;
int **array = (int **)calloc(num1,sizeof(int *));
for(int i=0;i<num1;i++)
{
array[i] = (int *)calloc(num2,sizeof(int));
}
for(int i=0;i<num1;i++)
{
for(int j=0;j<num2;j++)
{
array[i][j] =i*num2+j+1;
printf("%d\t",array[i][j]);
}
printf("\n");
}
for(int i=0;i<num1;i++)
{
free(array[i]);
}
free(array);
return 0;
}
|