有关malloc和new的详细解释
①.函数原型:
void * malloc(unsigned int num_bytes); //分配长度为num_bytes字节的内存块
LinkList List_HeadInsert(LinkList &L)
{
L=(LinkList)malloc(sizeof(LNode))
//code
return L;
}
返回值是void指针,void* 表示未确定类型的指针,void *可以指向任何类型的数据,更明确的说是指申请内存空间时还不知道用户是用这段空间来存储什么类型的数据(比如是char还是int或者其他数据类型),可以通过类型强制转化转化为其他任意类型指针。如果分配成功则返回指向被分配内存的指针(此存储区中的初始值不确定),否则返回空指针NULL。malloc申请到的内存中的值是随机的
②. void 指针 和free
我们之前说过:
void * p1;
int *p2;
p1 = p2; //p1变成了一个int型的指针了,void型指针可以自动转化为其他类型的指针,前提都是指针
Have a corresponding free to every malloc. 每个malloc都要有free,有分配内存,当我们不需要时对内存进行释放,否则浪费很多内存资源,也会出现许多内存碎片。
③.malloc如何申请内存的?
如果用户申请分配一个较大的内存空间,那么空闲链上可能没有符合用户要求的内存块了,这个时候,
malloc()函数请求延时,并开始在空闲链上翻箱倒柜的检查各内存块,对他们进行 整合 ,将相邻的小内存块合并成较大的内存块。如果无法获得符合用于要求的内存空间,那么malloc()函数就会返回NULL,因此,调用malloc()函数的时候,一定要判断它的返回值是否为NULL。
在操作系统中,我们知道管理空闲盘块的方法有:
成组链接法,空闲表法、空闲链表法和位示图法。
Q1:void *指针和普通的指针有什么区别?
Q2:malloc中动态分配的自增到底是什么样的自增?
Q3:new运算符怎么实行动态分配的?
Q4:所申请的空间 动态分配失败是怎么回事?
Q5:malloc和new所申请的空间不用时是怎么样销毁的?
PS:本日linux学习笔记