9

我有一个想法,我无法弄清楚新运算符重载。假设,我有一个类 MyClass 但 MyClass.h MyClass.cpp 和 main.cpp 文件是这样的;

//MyClass.h

class MyClass {
   public:
     //Some member functions
     void* operator new (size_t size);
     void operator delete (void* ptr);
     //...
};

//MyClass.cpp

void* MyClass::operator new(size_t size) {
   return malloc(size);
}

void MyClass::operator delete(void* ptr) {
   free(ptr);
}

//main.cpp

//Include files
//...

int main() {
   MyClass* cPtr = new MyClass();
   delete cPtr
} 

分别。这个程序运行得很好。但是,我无法理解的是,为什么 new 运算符可以在没有任何参数的情况下被调用,而在它的定义中它有一个像“size_t size”这样的函数参数。我在这里缺少一点吗?谢谢。

4

3 回答 3

7

不要将“new 表达式”与“operator new”分配函数混淆。前者导致后者。当您说 时T * p = new T;,这首先调用分配函数以获取内存,然后在该内存中构造对象。该过程大致等同于以下内容:

void * addr = T::operator new(sizeof(T));    //  rough equivalent of what
T * p = ::new (addr) T;                      //  "T * p = new T;" means.

(加上构造函数抛出的异常处理程序;在这种情况下,内存将被释放。)

于 2013-05-19T22:53:16.243 回答
1

new-expressionnew MyClass()基本上分两步定义。首先它调用你已经重载的分配器函数来获得一些分配的内存。它将类型的大小传递MyClass给该分配器函数,这就是size_t需要参数的原因。在此之后,它在分配的内存中构造一个对象并返回一个指向它的指针。

于 2013-05-19T22:52:37.357 回答
0

编译器知道你的类的大小。基本上,它正在传递sizeof(MyClass)到您的new函数中。

于 2013-05-19T22:52:13.167 回答