C语言:什么时候要用到malloc?

2024-12-26 03:07:00
推荐回答(3个)
回答1:

malloc函数的实质体现在,它有一个将可用的内存块连接为一个长长的列表的所谓空闲链表。调用malloc函数时,它沿连接表寻找一个大到足以满足用户请求所需要的内存块。然后,将该内存块一分为二(一块的大小与用户请求的大小相等,另一块的大小就是剩下的字节)。接下来,将分配给用户的那块内存传给用户,并将剩下的那块(如果有的话)返回到连接表上。调用free函数时,它将用户释放的内存块连接到空闲链上。到最后,空闲链会被切成很多的小内存片段,如果这时用户申请一个大的内存片段,那么空闲链上可能没有可以满足用户要求的片段了。于是,malloc函数请求延时,并开始在空闲链上翻箱倒柜地检查各内存片段,对它们进行整理,将相邻的小空闲块合并成较大的内存块。如果无法获得符合要求的内存块,malloc函数会返回NULL指针,因此在调用malloc动态申请内存块时,一定要进行返回值的判断。

回答2:

#include
#include
int
main()
{
float
a;
char
str[1024];
gets(str);
printf("%s",str);
}
在输入小于1024个字符就不会错误了
程序1运行的时候肯定
会错的,gets的字符串赋值给一个空的,
malloc动态分配空间

回答3:

c学数据结构的时候,是个数据存储都会和malloc扯上,这很正常!因为内存要讲究释放,所以感觉int a,没有malloc好,像C++就特别喜欢New和delete