我有一个观点,我无法弄清楚新的运算符重载。 假设,我有一个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”的函数参数。我在这里失踪了吗? 感谢。
答案 0 :(得分:6)
不要将“new expression”与“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.
(在构造函数抛出的情况下加上异常处理程序;在这种情况下将释放内存。)
答案 1 :(得分:1)
新表达式new MyClass()
基本上分两步定义。首先,它调用已经重载的allocator函数来获取一些已分配的内存。它将类型MyClass
的大小传递给该分配器函数,这就是需要size_t
参数的原因。在此之后,它在该分配的内存中构造一个对象并返回一个指向它的指针。
答案 2 :(得分:0)
编译器知道你的类的大小。基本上,它会将sizeof(MyClass)
传递到您的new
函数中。