c++重载运算符new delete

c++ overload operator new delete,

本文关键字:delete new 运算符 重载 c++      更新时间:2023-10-16

嗨,这有点复杂,所以如果这些都没有意义,请告诉我,我们的团队正在编写一个C++应用程序,我们之前已经重载了运算符new。最近我偶然发现了这篇文章:http://www.flipcode.com/archives/How_To_Find_Memory_Leaks.shtml关于如何通过内存分配获得调试信息。

应用程序#中的所有文件都包括一个文件,其中我们有编译时平台配置,在该文件中我添加了以下内容:

#ifdef _DEBUG
void* operator new(size_t size, const char *filename, const char *funcname, int line);
void* operator new[](size_t size, const char *filename, const char *funcname, int line);
#define new new(__FILE__, __FUNCSIG__, __LINE__)
#endif

由于我们只为平台构建链接libcmt.lib,为了使用STL,我删除了运算符new的旧实现,它看起来像:

// in a .cpp file:
void*
operator new(size_t size) { ... }

并将其替换为:

// in the same .cpp file as above...
#undef new
void* operator new(size_t size, const char *filename, const char *funcname, int line) { ... }
#define new new(__FILE__, __FUNCSIG__, __LINE__)

这对编译来说很好,但我从libcmt.lib:中得到了一堆链接器错误

例如:libcmt.lib(malloc.obj):错误LNK2001:未解析的外部符号__imp_HeapAlloc

添加回运算符new的旧实现(没有附加参数)可以使链接器成功地链接所有内容。

我的问题是:我想让libcmt看到我的宏(#define new new(FILEFUNCSIGLINE)),因此当它链接时,请尝试并链接我定义的版本(与调试宏)。

我该如何让它发挥作用??(我还尝试使用visualstudio中的属性表来定义宏)

你无法让它工作。如果在包含标准标头的任何文件中定义了此宏,则行为未定义。当然,一个项目的正常发展将导致人们定义类本地operator new,或者使用placementnew,或者这个宏将打破的许多技术中的任何一种。它与#define while if处于同一级别。即使不使用标准库,在宏中重新定义关键字也肯定会遇到麻烦。