malloc()
声明:
void* malloc(int size);
说明:
头文件:stdlib.h size:要申请的内存空间的大小 void* :返回类型,要使用需要强制转换 释放:通过free() 释放
示例:
int *p = NULL;
p = (int*)malloc(sizeof (int)*10);
for(int i = 0; i < 10; i++)
{
p[i] = i;
printf("p[%d]: %d\n",i,p[i]);
}
printf("p[10]: %d\n",p[10]);
即使 读取后十几个,二十几个,其实都不会报错,但是如果数量太多就会报错,这是因为遇到了分页,上述例子在操作 p[10] 报错的概率其实很小,除非 p[9] 的逻辑地址 恰好在 当前物理页面的末尾,这会导致报错。 在C++中有一个概念叫做 超尾 ,这个概念在C primer 里面提及过,你猜它们是否有关联?
realloc()
声明:
void* realloc( type* p,int size);
说明:
头文件:stdlib.h size:要申请的内存空间的大小 void* :返回类型,要使用需要强制转换 p:已存在的内存指针 释放:通过free() 释放
示例:
int *p = NULL;
p = (int*)malloc(sizeof (int)*10);
for(int i = 0; i < 10; i++)
{
p[i] = i;
printf("p[%d]: %d\n",i,p[i]);
}
printf("p[10]: %d\n",p[10]);
int *q = NULL;
q = realloc(p,sizeof (int)*20);
for(int i = 0; i < 20; i++)
{
printf("q[%d]: %d\n",i,q[i]);
}
realloc在原有p指针指向的空间的基础上扩充了空间。如果把malloc 那个给p[10]赋值注释去掉,不会报错,p[10]也能打印出来,但是realloc 无法再扩充空间。realloc同样也能缩小空间。
calloc()
声明:
void *calloc(int n, int size);
说明:
头文件:stdlib.h size:要申请的内存空间的大小 void* :返回类型,要使用需要强制转换 n:申请的个数 释放:通过free() 释放
这三个函数的返回值都是 void* ,按道理来讲,都是需要类型转换的,并且,这三个函数都是在堆中申请内存,用free释放内存,calloc() 和 malloc() 可以说没有什么区别。
|