1

我正在使用预处理器#define 宏来计算头文件中的函数数量:

#define __INDEX -1

//First group of functions
void func1(void);
#define __FUNC1_INDEX __INDEX + 1
void func2(void);
#define __FUNC2_INDEX __FUNC1_INDEX + 1
#undef __INDEX
#define __INDEX __FUNC2_INDEX

//Second group of functions
void func3(void);
#define __FUNC3_INDEX __INDEX + 1
void func4(void);
#define __FUNC4_INDEX __FUNC3_INDEX + 1
#undef __INDEX
#define __INDEX __FUNC4_INDEX

//Third group of functions
void func5(void);
#define __FUNC5_INDEX __INDEX + 1
void func6(void);
#define __FUNC6_INDEX __FUNC5_INDEX + 1
#undef __INDEX
#define __INDEX __FUNC6_INDEX

#define __NUM_FUNCTIONS __INDEX + 1

预处理器通过前两组函数就好了,但是当它到达该行时:

#define __FUNC5_INDEX __INDEX + 1

我收到 __INDEX 的“未在此范围内定义”错误。真正令人困惑的是,在第二组函数中[成功地]完成了同样的事情。__FUNC3_INDEX 取 __INDEX + 1 的值。据我所知,任何地方都没有错别字……有什么问题?

我正在使用 g++ 4.8。

4

1 回答 1

2

你不能指望预处理器宏。它们只是字符串扩展。

预处理器完成后:

#define __FUNC5_INDEX __INDEX + 1
#define __FUNC6_INDEX __FUNC5_INDEX + 1
#undef __INDEX
#define __INDEX __FUNC6_INDEX

以下定义有效:

__FUNC5_INDEX → __INDEX + 1
__FUNC6_INDEX → __FUNC5_INDEX + 1
__INDEX → __FUNC6_INDEX

没有进行任何计算。更重要的是,指令内部不会执行替换。#define

现在,当您尝试扩展__INDEX(可能作为 扩展的一部分)时__NUM_FUNCTIONS,将发生以下情况:

__INDEX → __FUNC6_INDEX
        → __FUNC5_INDEX + 1
        → __INDEX + 1 + 1

此时,宏扩展停止,因为您无法在其自身的扩展中扩展宏。令牌保持原样。

因此,您最终将__INDEX在程序中使用符号作为变量。但是由于该变量__INDEX从未被定义,因此您会收到错误消息。

顺便说一句,不要使用以下划线开头的符号,或者一个下划线和一个大写字母开头的符号。这些是为标准库保留的。

于 2013-10-24T04:04:08.837 回答