因为是做上位机的软件开发,测试代码的调试需要测试仪表配合,才可以顺利执行。在公司使用示波器,频谱仪很方便的按照整个测试流程来debug,但是如果没有这些仪器的话,就需要注释掉这些代码。假如说在家做调式注释掉,在公司实际调式又得取消注释,这样就很麻烦,所有编译时要使用预处理器指令,方便调式。
使用预处理指令可以禁止编译器编译某一部分代码。假如软件有2个版本,完整版和简化版可以使用预处理指令。预处理指令都是以# 开头。
下面简要介绍C#中常用的预处理指令:
1.#define ,#undef —必须在源文件开头申明
#define ONTESTBENCH 告诉编译定义了 ONTESTBENCH变量,这个变量没有真正的值,只是存在而已。不是实际代码的一部分,只是在编译时存在。
#undef ONTESTBENCH 删除变量的定义
如果变量不存在,#undef就没有任何作用。
2.#if,#elif, #else, #endif
这些指令告诉编译器是否要编译某个代码块。
这里写代码片#define ONTESTBENCH
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace Test
{
class Program
{
static void Main(string[] args)
{
#if ONTESTBENCH
Console.WriteLine ("Test program On test bench!");
#else
Console.WriteLine ("Test program Not On test bench!");
#endif
Console.ReadLine ();
}
}
}
输出:
如果注释第一行:// #define ONTESTBENCH
输出:
还可以多条件定义:
这里写代码片#define ONTESTBENCH
#define PICOSCOPE //示波器
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace Test
{
class Program
{
static void Main(string[] args)
{
#if ONTESTBENCH && PICOSCOPE //多个条件编译,既在测试台中,而且配有PicoScope示波器
Console.WriteLine ("Test program On test bench and have Picoscope!");
#else
Console.WriteLine ("Test program Not On test bench!");
#endif
Console.ReadLine ();
}
}
}
输出:
3.#warning ,# error
当编译器遇到它们时,分别产生警告或错误。
**#warning 指令 给用户显示#warning后面的文本,之后编译继续进行。
#error指令给用户显示后面的文本,作为一条编译错误消息,然后立即退出编译,不生产IL代码。**
这里写代码片using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace Test2
{
class Program
{
static void Main(string[] args)
{
#warning "Start Test"
Console.WriteLine("Command1 execute");
#warning "Test End"
Console.WriteLine ("End!");
#error "Error!!!"
Console.ReadLine ();
}
}
}
4.#region, #endregion
把一段代码标记为有名称的一个代码块,时代码布局清晰易读。
4.#lines ,#line default
#lines 改变编译器在警告和错误信息中显示的文件名和行号信息。**
5.#program 抑制或还原指定的编译警告。
#program warning disable 168
//do something ….
#program warning restore 168