23

我目前正在开发一个用 MFC C++ 编写的已经开发的项目,并且面临一个已经存在的宏的问题,该宏具有以下定义:

#define HEIGHT_TESTS 13

我正在尝试从代码中更改值,但我认为由于它是一个预处理定义,我无法做到这一点。有没有一种方法可以解决这个问题,而无需整体更改原始宏(因为它可能会影响程序的原始功能)。我只是打算在一种特定条件下更改它,在其他任何地方都保持不变。

只是为了让大家知道,我显然已经尝试过使用不同的宏定义,我打算使用值 (17),但没有运气。

任何帮助将非常感激。

4

2 回答 2

47

您可以一次又一次地undef输入它define

#include <iostream>

#define AAA 13

int main()
{
    #undef AAA
    #define AAA 7
    std::cout << AAA;
}

输出:7

请注意,以 开头的语句#预处理器指令,甚至在编译代码之前就已经处理好了。在这种情况下,这个常量AAA将被 简单地替换7,即它就像文本替换一样工作,没有额外的语法检查,没有类型安全等......

...这就是为什么你应该避免使用#define可以被静态函数和变量替换的宏和 s 的主要原因:)


为什么要“文本替换”?

看看这段代码:

#include <iostream>

#define AAA 13

void purePrint() {
    std::cout << AAA;
}

void redefAndPrint() {
    #undef AAA
    #define AAA 7
    std::cout << AAA;
}

int main()
{
    #undef AAA
    #define AAA 4
    purePrint();
    redefAndPrint();
    purePrint();
}

预处理器从上到下逐行执行,执行以下操作:

  • 啊,,#define AAA 13所以AAA下次我打的时候,我会放在那里13
  • 看,purePrint 使用AAA,我将其替换为13
  • 等等,现在他们告诉我使用7,所以我将停止使用13
  • 所以在这里redefAndPrint()我会放在那里7

将给定的代码转换成这个:

#include <iostream>

void purePrint() {
    std::cout << 13;
}

void redefAndPrint() {
    std::cout << 7;
}

int main()
{
    purePrint();
    redefAndPrint();
    purePrint();
}

它将输出13713并且最新的#define AAA 4根本不会被使用。

于 2012-02-14T09:35:56.610 回答
5

类似于以下内容:

#undef HEIGHT_TESTS
#define HEIGHT_TESTS 17

// Use redefined macro

// Restore
#undef HEIGHT_TESTS
#define HEIGHT_TESTS 13
于 2012-02-14T09:35:12.667 回答