所谓局部重载 即在类当中重载new 和delete 方法
众所周知 C++实例化类时一般的方法都是分配一块内存对象 即DD *mm = new DD() 这种类型,所以如果我们能对new方法进行重载,即给里面加入我们自己想要达到的效果,就能更好的对内存进行管理,重载的方法主要是通过operator方法,接下来看一下我写的例子。
首先是头文件,即是对Student类的声明:
#include "stdafx.h"
using namespace std;
class Student
{
public:
Student();
~Student();
//重载new和delete方法
void* operator new(std::size_t cur_size);
void operator delete(void* ptr);
};
可以看出 在Student类里面 声明了构造函数和析构函数方法,以及重载了new和delete方法(插句题外话:重载和hook还挺像的)
接下来是cpp 对类的实现
// RamOperate.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include "OperateDemo.h"
using namespace std;
Student::Student()
{
std::cout << "测试是否重载"<<endl ;
}
Student::~Student()
{
std::cout << "退出之后调用这个函数" << endl;
}
void* Student::operator new(std::size_t cur_size)
{
cout << "new 被重载了" << endl;
void* cur_address = malloc(cur_size);
return cur_address ;
}
void Student::operator delete(void * ptr)
{
cout << "删除被重载了"<< endl;
free(ptr);
}
接下来主函数中测试这个方法
int _tmain(int argc, _TCHAR* argv[])
{
Student * cur_object = new Student();
cout << "new和delete分隔符-----" << endl;
delete cur_object;
cout << "cxk"<< endl;
return 0;
}
运行结果如下:
可以明显的看出 new和delete方法被重载了 而且 得到两个结论
1.当创建对象的时候,会先执行分配内存的方法 然后再执行 构造函数
2.当删除对象的时候,会先析构 再删除内存