时间:2021-05-20
预处理指令
这些指令/命令不会转换为可执行代码,但会影响编译过程的各个方面;列如,可以让编译器不编译某一部分代码等。
C#中主要的预处理指令
#define和#undef
#define指令定义:
#define DEBUG它告诉编译器存在DEBUG这个符号;这个符号不是实际代码的一部分,而只是在编译器编译代码时候可能会根据这个符号做条件编译。
#undef定义:
#undef DEBUG用来移除定义的符号DEBUG。如果不存在这样的标记,#undef指令则不会生效。同样,用#define再次定义一个同名的标记也不会有任何变化。
注意:
#if, #elif, #else和#endif
这些指令告诉编译器是否要编译包含在其中的代码块。例如:
int DoSomeWork(double x){ // do something #if DEBUG Console.WriteLine($"x is {x}"); #endif}这段代码中的Console.Writeline语句,只有在前面用#define指令定义了符号DEBUG后才会在编译的时候,真正被编译到;
如果编译器没发现DEBUG符号,就会在编译的时候忽略这句代码。
#elif(= else if)和#else指令可以用在#if块中:
#define ENTERPRISE#define W10// further on in the file#if ENTERPRISE// do something #if W10 // some code that is only relevant to enterprise // edition running on W10 #endif#elif PROFESSIONAL// do something else#else// code for the leaner version#endif#if和#elif还支持有限的一些逻辑操作符,你可以用使用!,==,!=和||等。
一个标记如果存在,则认为是true,如果没有定义,就认为是false,因此你也可以这样使用:
#if W10 && (ENTERPRISE==false) // if W10 is defined but ENTERPRISE isn't#warning和#error
当编译器遇到#warning的时候,会产生警告信息;
当编译器遇到#error的时候,会产生错误信息;
class Program { static void Main(string[] args) { #warning this is a warning message which will be shown when compile Console.WriteLine("Hello World!"); #error this is a error message, and will break build } }编译结果:
Program.cs(10,10): warning CS1030: #warning: 'this is a warning message which will be shown when compile' [/define_warning/define_warning.csproj]
Program.cs(14,8): error CS1029: #error: 'this is a error message, and will break build' [/define_warning/define_warning.csproj]
1 Warning(s)
1 Error(s)
使用这些指令可以检查#define语句是不是做错了什么事,使用#warning可以提醒要做些事情:
#if DEBUG && RELEASE#error "You've defined DEBUG and RELEASE simultaneously!"#endif#warning "Don't forget to remove this line before the boss tests the code!"Console.WriteLine("*I love this job.*");#region和#endregion
可以用来标识一段代码,在Visual Studio或其他能够识别的IDE里比较有用。
#region Member Field Declarationsint x;double d;Currency balance;#endregion#line
#line指令可以用来改变编译器输出警告和错误时相应的文件名和行号信息。这个实际中,用的可能会比较少。
主要是在用第三方包的时候,有时候会导致编译器报告的行号或文件名与实际不匹配。
#line可以用于还原这种匹配。
#line 164 "Core.cs" // We happen to know this is line 164 in the file Core.cs,// before the intermediate package mangles it.// later on#line default // restores default line numbering#pragma
#pragma指令可以用来终止或恢复某个指定编号到编译器警告。
与命令行选项不同,#pragma指令可以在类或方法级别实现。
例如:
class Program{ static void Main(string[] args) { int i = 0; Console.WriteLine("Hello World!"); }}编译是会有warning:
Program.cs(9,17): warning CS0219: The variable 'i' is assigned but its value is never used [/define_warning/define_warning.csproj]
1 Warning(s)
0 Error(s)
从warning信息可以看出是warning CS0219,加入#pragma后就不会有warning了。
#pragma warning disable CS0219 public class Program { static void Main(string[] args) { int i = 0; Console.WriteLine("Hello World!"); } }#pragma warning restore CS0219注意:warning的代码是区分大小写的,CS2019要大写,如果写成cs2019则没有用。
以上就是c#预处理指令分析的详细内容,更多关于c#预处理指令的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了C#预处理器指令的用法。分享给大家供大家参考。具体用法分析如下:C#预处理器指令是在编译时调用的。预处理器指令(preprocessordirec
什么是预处理指令符?当C#编译器找到一条预处理指令#if,最后找到一条指令时,#endif仅在定义了指定符号的情况下,编译器才会在这些指令之间编译代码。与C和C
本文导读:C#的预处理器指令从来不会转化为可执行代码的命令,但是会影响编译过程的各个方面,常用的预处理器指令有#define、#undef、#if,#elif,
预处理器是一些指令,指示编译器在实际编译之前所需完成的预处理。所有的预处理器指令都是以井号(#)开头,只有空格字符可以出现在预处理指令之前。预处理指令不是C++
#pragma#pragma预处理指令详解在所有的预处理指令中,#Pragma指令可能是最复杂的了,它的作用是设定编译器的状态或者是指示编译器完成一些特定的动作