//malloc它的作用是申请一段动态内存,参数的作用是:要申请多少字节的空间
//举个eg:假如能够放n个整数
#define N 10
#include <stdio.h>
#include <stdlib.h>
int main()
{
int* p,*q,*r;
int i;
if ((p = (int*)malloc(N * sizeof(int))) == NULL)//NULL代表申请失败
{
return -1;
}
//如果申请成功,就可以往内存中放入一些值,对于malloc来说,它申请的内存默认
//是没初始化的,故:需咱们手动写一哈
for (i = 0; i < N; i++)
{
p[i] = 2 + i;
printf("%d ", p[i]);
}
puts(" ");
if ((q = (int*)calloc(N, sizeof(int))) == NULL)
{
return -1;
}
for (i = 0; i < N; i++)
{
printf("%d ", q[i]);
}
//问题:calloc和realloc都是申请动态内存,让我们来看看calloc的使用方法
//如果说大家有看过C的官方文档,可以晓得calloc是有两个参数的,第一个是
//你要申请的这个 个数,第二个是每一个元素的地址
//举个列子:比如咱们要申请10个整数,10就要写到第一个参数里,然后整型的大小
//写在后边,返回值就是获得内存空间的起始地址
//那如果咱们想跟malloc 函数申请的空间保持一样呢? 咱们是不是要把它拆成两个
//参数
//到这需注意:这里有个特别的地方 calloc 和 malloc 相比,它所申请的内存是被
//初始化的,也就是说每个字节都为0
//在来说说 realloc,看过C文档的都应该晓得,它前面的第一个参数是一个指针!
//解释一哈realloc:对想要申请的空间进行调整,如果说想要申请更多的内存,这
//时指针存放的是你之前的那个地址,后边的那个大小是当你扩容之后,你整段空间
//的大小,可能也不一定是扩容,同样也可以是减小,一般扩容多
if ((r = (int*)realloc(p, 2 * N)) == NULL)
{
return -1;
}
for (i = 0; i < 2 * N; i++)
{
printf("%d ", r[i]);
}
puts(" ");
free(p);
p = NULL;
free(q);
q = NULL;
free(r);
r = NULL;
//假如咱们对p所指向的这段内存进行空间重新分配,第一个参数就写p,扩容多少的话,咱们就扩容1倍
//问题:这是有些人就有疑问了,当申请空间之后,原来的内容是否还在?扩充出来的这段空间,
//它的初始值是多少? 那我只能说 朋友你把代码拿去跑跑就明白啦!
//之前的值都是存在的,后面的值会变成随机值!,这就是realloc的一个特性
//总结:这三个函数的释放是一样的
void *malloc(size_t size);//分配内存,不会把内存清零
void *calloc(size_t numitems, size_t size);//分配内存,把内存清零
void* realloc(void* ptr, size_t size);//重新分配内存,把之前的数据移动到新内存中去
//拓展: realloc(NULL,size) 等价于 malloc(size)
//calloc(num,size) 基本上等于 void *p = malloc(num *size); memset(p,0,num *size);
return 0;
}
最最后说一句:如果说文章有帮助到你,记得给UP点个赞,你的赞就是我更新的动力!