为什么C++预处理器没有对枚举值进行正确的运算
Why is the C++ preprocessor not doing arithmetic properly on enum values?
以下代码不生成#error
,而是编译、运行并输出跟踪值37(TT_LAST_PARM等于53,TT_FIRST_PARM等于16):
#if ((TT_LAST_PARM - TT_FIRST_PARM) >= 32)
#error More than 32 parm tokens
#else
HTRACE("%d", TT_LAST_PARM - TT_FIRST_PARM);
#endif
如果我对值进行硬编码,
#if ((53 - 16) >= 32)
#error More than 32 parm tokens
#else
HTRACE("%d", 53 - 16);
#endif
预处理器确实生成错误:
错误1致命错误C1189:#错误:超过32个parm令牌d:\codeMTX\Knowbase\KBMatL\PrintParser.CPP 2663
enum
是C/C++关键字,而不是预处理器指令
预处理器指令由一个前导#
符号清楚地表示。
预处理器没有/知道一个称为TT_LAST_PARM
的符号等,根据C++标准(§16.1¶4):
由于宏扩展和定义的一元运算符执行了所有替换后,除true和false外,所有剩余的标识符和关键字都将替换为pp编号0
因此您的表达式计算为(0 - 0) >= 32
相关文章:
- 不带大括号的枚举形式
- 枚举环境变量的惯用C++14/C++17方法
- 类似枚举的计算常量
- 如何正确实现和访问运算符的各种自定义枚举器
- 错误:从"int"到枚举c++的转换无效
- C++中构造函数中的枚举
- 访问在 C++ 结构中声明的枚举变量
- 枚举类'classname'的多重定义
- 强枚举类型定义:Clang Bug 还是 C++11 标准不确定性?
- typedef 枚举和枚举类有什么区别?
- 为什么我的开关/机箱在使用枚举时默认?
- 标准::可选枚举的比较运算符
- C++两个源文件之间共享的枚举的静态实例
- 打印没有铸件的枚举可以在C++中吗?
- 枚举成员与静态 int 成员?
- C++:枚举:错误:应使用标识符而不是"}"
- 带有 c++ 的枚举(输入检查)
- 在 qml 中使用 Q_ENUM 和 Q_PROPERTY 作为枚举类
- 为什么C++预处理器没有对枚举值进行正确的运算
- 在浮点运算上执行平方运算和平方根运算时:表达式必须具有整型或非整型枚举类型