关于Linux进程管理,从面向对象到底层的讨论
delete或者free的内存,真的是释放了吗?
delete操作符:
delete是C++语言自带的运算符,它专门用于释放由new操作符分配的内存或用于空指针。
delete在释放内存时,会调用对象的析构函数来确保对象的清理和资源释放。这是非常重要的,因为析构函数通常用于执行一些清理工作,如关闭文件、释放其他资源等。
delete在释放内存后,能够确保内存内容被释放,并合并成一块可用的空间,这在长时间运行的程序中尤其重要,可以减少内存碎片。
free函数:
free是C标准库函数,它只能用于释放由malloc()、calloc()、realloc()分配的内存或用于空指针。
与delete不同,free在释放内存时不会调用析构函数。因此,如果释放的是类(或结构体)对象的内存,那么对象的析构函数将不会被调用,这可能会导致资源泄露或其他问题。
free只是简单地将内存地址修改为空闲状态,并不能保证合并成一块可用的空间。如果频繁地执行malloc和free,容易产生大量小块内存碎片,这可能会影响程序的运行效率。
内存释放的具体实现:
对于malloc使用mmap分配的内存(大于128k),free会调用munmap系统调用马上还给操作系统,实现真正释放。
对于堆内的内存,只有在释放堆顶的空间,同时堆顶总连续空闲空间大于128k时,glibc的free实现才会使用sbrk(-SIZE)来回收内存,真正归还给操作系统。堆内的其他空闲空