目录
一、内存分配的每一层面
1、C++用于内存管理的工具
①malloc的使用(C函数)
void* p1= malloc(512);//512 bytes
free(p1);
②new的使用(C++表达式)
complex* p2 = new complex;//一个对象
delete p2;
(new做两步操作:分配内存;执行构造函数)
③::operator new的使用(C++函数)
void* p3=::operator new(512);//512bytes
::operator delete(p3);
④allocator::allocate()的使用(C++标准库)
编译器不同,接口不同
新版本GNUC
2、不同内存管理工具的解释
①new expression
placement new:
new(mem) Complex(1,2);
new handler
当operator new分配内存出错,抛出异常之前会调用new handler即代码中的_callnewh;
new handler的使用:
查看编译器如何处理new的方法:
(1)使用new处设置断点并调试;
(2)菜单栏-调试-窗口-反汇编 ;即可查看汇编代码
【总结】观察反汇编代码可见编译器处理new运算符时会先分配内存,再调用构造函数
②delete expression
先调用析构函数,然后释放内存
③array new
Complex* pca=new Complex[3];//调用3次Complex类的构造函数
cookie里记录分配内存的长度
delete[] pca;//调用3次Complex类的析构函数
内存泄露发生于:若类对象里含有指针,析构函数会释放指针指向的内存,delete psa只调用了一次析构函数,可能会有内存未释放;
Complex为复数,内部不包含指针,析构函数没有作用,所以即使使用delete pca也不会发生内存泄露
array new :int 析构函数无意义
malloc时不满16的整数倍会填补,此处pad=12 bytes
array new :object 析构函数有意义
④placement new
可以将对象构建于已经分配好的内存中;
没有所谓的placement delete,因为placement new没有分配内存
或者称与placement new对应的operator delete为placement delete