2

我在将我们的 C++ 代码从 VS2008 迁移到 VS2010 时遇到了问题。到目前为止,我找不到原因的解释,并感谢您的帮助。

我们有一个自定义内存分配器,它驻留在一个 dll 中。在其余代码中,我们使用预处理器将分配重定向到我们的函数。下面的简单代码在 VS2008 中编译正确,但在 VS2010 中编译不正确。

在 stdafh.h 中:

#define free my_free
#include <string>

在 VS2010 中,我得到:

1>d:\program files\microsoft visual studio 10.0\vc\include\xdebug(62): error C3861: 'free': identifier not found

来自线路:

template<class _Ty>
    void __CLRCALL_OR_CDECL _DebugHeapDelete(_Ty *_Ptr)
    {   // delete from the debug CRT heap even if operator delete exists
    if (_Ptr != 0)
        {   // worth deleting
        _Ptr->~_Ty();
        // delete as _NORMAL_BLOCK, not _CRT_BLOCK, since we might have
        // facets allocated by normal new.
        free(_Ptr);

任何帮助或想法将不胜感激!

摩西

4

2 回答 2

6

根据 C++ ISO 标准,第 17.4.3.1.1.2 节:

包含头文件的翻译单元不应包含定义在该头文件中声明或定义的名称的任何宏。这样的翻译单元也不应为在词法上与关键字相同的名称定义宏。

这意味着#define库函数名称具有其他含义是不合法的。我想这恰好在 VS2008 中工作,但是当迁移到 VS2010 时,编译器作者想出了一个不能正常工作的实现。

如果你想重新定义做什么free,我建议通过一个更传统的渠道来做这件事,将代码与你自己的 C 库实现链接起来,从而改变默认行为。

于 2011-01-20T10:02:05.687 回答
2

在使用 /P 选项创建预处理器文件并对其进行研究后,我找到了问题的根本原因。

xdebug 标头,将自己描述为“Microsoft 的调试堆支持标头”,包含以下几行:

#pragma push_macro("free")
#undef free

这显然挫败了我们重新定义它的尝试。所以这对编译器来说并不是什么新鲜事,只是简单的 #undef 恰好发生在我们尝试重新定义的函数中

于 2011-01-23T08:59:22.857 回答