malloc如何分配内存
Linux由glibc内存管理–ptmalloc2来分配内存:
ptmalloc2
想了解更多可以点上面的链接,我就不在赘述。
malloc函数返回一个void *指针,如下代码
typedef struct person
{
char *name;
int age;
} person_t;
person_t *p1 = (person_t *)malloc(sizeof(person_t));
/* 这样就申请了一个person_t结构体大小的内存 */
说到这就该说说如何分配内存了
首先,要知道malloc是在堆上开辟空间。也就是说函数返回的指针是指向堆里面的一块内存。操作系统中有一个记录空闲内存地址的链表。当操作系统收到程序的申请时,就会遍历该链表,然后就寻找第一个空间大于所申请空间的堆结点,然后就将该结点从空闲结点链表中删除,并将该结点的空间分配给程序。
什么是堆:堆是大家共有的空间,分全局堆和局部堆。全局堆就是所有没有分配的空间,局部堆就是用户申请的空间。堆在操作系统对进程初始化的时候分配,运行过程中也可以向系统要额外的堆,但是记得用完了要还给操作系统,要不然就是内存泄漏
什么是栈:栈是线程独有的,保存其运行状态和局部自动变量的。栈在线程开始的时候初始化,每个线程的栈互相独立。每个函数都有自己的栈,栈被用来在函数之间传递参数。操作系统在切换线程的时候会自动的切换栈,就是切换SS/ESP寄存器。栈空间不需要在高级语言里面显式的分配和释放。
下面说说free释放问题:free()到底释放了什么
malloc是把一块内存标记为不可被申请,而free其实是把当前申请的一块内存又重新标记为可使用
if(NULL == p1)
return;
free(p1);
p1 = NULL;
/* 释放后把指针置为NULL */
free和delete的区别是:free不会调用析构函数而delete会调用