当前位置:  编程技术>.net/c#/asp.net

C#预处理指令之#line,#pragma warning 详细解析

    来源: 互联网  发布时间:2014-10-27

    本文导语:  #line #line 使您可以修改编译器的行号以及(可选)错误和警告的文件名输出。下面的示例说明如何报告与行号关联的两个警告。#line 200 指令强迫行号为 200(尽管默认值为 #7)。另一行 (#9) 作为默认 #line 指令的结果跟在通常序...

#line
#line 使您可以修改编译器的行号以及(可选)错误和警告的文件名输出。下面的示例说明如何报告与行号关联的两个警告。#line 200 指令强迫行号为 200(尽管默认值为 #7)。另一行 (#9) 作为默认 #line 指令的结果跟在通常序列后。

代码如下:

class MainClass
{
     static void Main()
     {
         #line 200
         int i; // CS0168 on line 200
         #line default
         char c; // CS0168 on line 9
      }
}

备注:
#line 指令可能由生成过程中的自动中间步骤使用。例如,如果行从原始的源代码文件中移除,但是您仍希望编译器基于文件中的原始行号生成输出,则可以移除行,然后用 #line 模拟原始行号。 #line hidden 指令对调试器隐藏若干连续的行,这样当开发人员在逐句通过代码时,将会跳过 #line hidden 和下一个 #line 指令(假定它不是另一个 #line hidden 指令)之间的所有行。此选项也可用来使 ASP.NET 能够区分用户定义的代码和计算机生成的代码。尽管 ASP.NET 是此功能的主要使用者,但很可能将有更多的源生成器使用它。

#line hidden 指令不会影响错误报告中的文件名或行号。即,如果在隐藏块中遇到错误,编译器将报告当前文件名和错误的行号。

#line filename 指令指定您希望出现在编译器输出中的文件名。默认情况下,使用源代码文件的实际名称。文件名必须括在双引号 ("") 中。 源代码文件可以具有 #line 指令的任何编号。

示例
下面的示例说明调试器如何忽略代码中的隐藏行。运行此示例时,它将显示三行文本。但是,当设置如示例所示的断点并按 F10 键逐句通过代码时,您将看到调试器忽略了隐藏行。还请注意,即使在隐藏行上设置断点,调试器仍会忽略它。

代码如下:

// preprocessor_linehidden.cs
using System;
class MainClass
{
      static void Main()
      {
           Console.WriteLine("Normal line #1."); //这里设置断点
           #line hidden
           Console.WriteLine("Hidden line.");
          #line default
          Console.WriteLine("Normal line #2.");
       }
}

#pragma warning指令:允许我们关闭及重新开启警告消息

在日常开发的过程中我们总是会经常对代码进行编译,而在编译的过程中会出现许多信息,许多无用的警告信息总是会在便一点过程中提示出来,以干扰一些主要的警告,对此也是可以通过预处理器指令来进行关闭来阻止其显示,常见的警告如下(CS0219、CS0681等):

看一个例子:

代码如下:

public class C
{
    int i = 10;//警告:C.i已赋值,但从未使用过它的值

    [Obsolete("过期了",false)]
    public static void aa()
    {

    }


    static void Main()
    {
        int t=5; //警告:t已赋值,但其值从未使用
        aa(); //警告:过期了

    }
}


编译生成消息如下:

注意:我所使用的是vs2010如果多次编译会自动将警告去除,如希望确保警告在输出中被显示,可以为项目做下清理:

清理的作用就是将之前在bin目录中的程序集文件删除

如果我们希望不显示上图红框内的警告,我们可以用#pragma warning 指令来消除这些警告

在之前代码上添加预处理指令:

代码如下:

#pragma warning disable 0618,0219,0414
public class C
{

    int i = 10;//警告:C.i已赋值,但从未使用过它的值得

    [Obsolete("过期了",false)]
    public static void aa()
    {

    }


    static void Main()
    {
        int t=5; //警告:t已赋值,但其值从未使用
        aa(); //警告:过期了

    }
}


再次生成的时候发现警告消失了...
#pragma warning disable/restore 0618

其中disable/restore分别代表了禁用和开启警告,而后面的编号则代表了警告的编号,此处编写警告编号时无需以“CS”开头。

而这句代码只需书写在需要禁用或者开启的类文件中即可,这样此类对应的0618警告就不会出现了。

但是需要注意的是#pragma warning只对单个文件有作用,如果想禁用多个文件的警告可以使用编译器的/nowarn指令,具体可以见MSDN:点我进入

PS:#pragma 是一个单独的指令,而warning只是其中一个选项,#pragma的作用是:用于给编辑器提供特殊的指令,说明如何编译包含杂注的文件。


    
 
 

您可能感兴趣的文章:

 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • c/c++预处理命令预#error介绍
  • C/C++ 预处理器 CPIP
  • c/c++预处理命令预#undef介绍
  • C 预处理器 Ctpp
  • c/c++预处理命令预#pragma介绍
  • 文本预处理 caterpillars
  • c/c++预处理命令预#line介绍
  • CSS 预处理器 AbsurdJS
  • c/c++预处理命令预#include介绍
  • CSS预处理器 Less CSS
  • c/c++预处理命令预#,##使用介绍
  • 如何让codeblocks自动预处理所有include下面的头文件?
  • c/c++预处理命令预#if, #ifdef, #ifndef, #else, #elif, #endif介绍
  • 预处理器条件删除工具 unifdef
  • c/c++预处理命令预#define语法和例子
  • GObjects 预处理器 GOB
  • c/c++预处理命令之预定义变量
  • CSS预处理器 Stylus
  • gcc的预处理命令有输出提示信息的没有?
  • 前端预处理器语言图形编译工具 Koala App
  • VC中的预处理程序定义 在makefile中如何表达啊?(望高手指点)


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3