声明指令用于定义或取消定义条件编译符号。 pp-declaration:(pp 声明:) whitespaceopt # whitespaceopt define whitespace conditional-symbol pp-new-line(空白可选 # 空白可选 define 空白 条件符号 pp 新行)whitespaceopt # whitespaceopt undef whitespace conditional-symbol pp-new-line(空白可选 # 空白可选 undef 空白 条件符号 pp 新行) pp-new-line:(pp 新行:) whitespaceopt single-line-commentopt new-line(空白可选 单行注释可选 新行) 对 #define 指令的处理使给定的条件编译符号成为已定义的(从跟在指令后面的源代码行开始)。类似地,对 #undef 指令的处理使给定的条件编译符号成为未定义的(从跟在指令后面的源代码行开始)。 源文件中的任何 #define 和 #undef 指令都必须出现在源文件中第一个“标记”(第 2.4 节)的前面,否则将发生编译时错误。直观地讲,#define 和 #undef 指令必须位于源文件中所有“实代码”的前面。 示例:#define Enterprise #if Professional || Enterprise #define Advanced #endif namespace Megacorp.Data { #if Advanced class PivotTable {...} #endif } 是有效的,这是因为 #define 指令位于源文件中第一个标记(namespace 关键字)的前面。 下面的示例产生编译时错误,因为 #define 指令在实代码后面出现:#define A namespace N { #define B #if B class Class1 {} #endif } #define 指令可用于重复地定义一个已定义的条件编译符号,而不必对该符号插入任何 #undef。下面的示例定义一个条件编译符号 A,然后再次定义它。#define A #define A #undef 指令可用于取消定义一个本来已经是未定义的条件编译符号。下面的示例定义一个条件编译符号 A,然后两次取消定义该符号;第二个 #undef 没有作用但仍是有效的。#define A #undef A #undef Ahttp://www.bc-cn.net/Article/net/cs/jc/200511/1128.html

评论