C# 语言规范--2.5.3 声明指令

发表于:2007-07-14来源:作者:点击数: 标签:
C# 语言规范--2.5.3 声明指令: 声明指令用于定义或取消定义条件编译符号。 pp-declaration: (pp 声明:) whitespace opt # whitespace opt define whitespaceconditional-symbolpp-new-line (空白可选 #空白可选 define空白 条件符号 pp 新行) whitespa
C# 语言规范--2.5.3 声明指令:

声明指令用于定义或取消定义条件编译符号。

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#endifnamespace Megacorp.Data{   #if Advanced   class PivotTable {...}   #endif}

是有效的,这是因为 #define 指令位于源文件中第一个标记(namespace 关键字)的前面。

下面的示例产生编译时错误,因为 #define 指令在实代码后面出现:

#define Anamespace N{   #define B   #if B   class Class1 {}   #endif}

#define 指令可用于重复地定义一个已定义的条件编译符号,而不必对该符号插入任何 #undef。下面的示例定义一个条件编译符号 A,然后再次定义它。

#define A#define A

#undef 指令可用于取消定义一个本来已经是未定义的条件编译符号。下面的示例定义一个条件编译符号 A,然后两次取消定义该符号;第二个 #undef 没有作用但仍是有效的。

#define A#undef A#undef A



原文转自:http://www.ltesting.net