#line
#line 使您可以修改編譯器的行號以及(可選)錯誤和警告的文件名輸出。下面的示例說明如何報告與行號關聯的兩個警告。#line 200 指令強迫行號為 200(盡管默認值為 #7)。另一行 (#9) 作為默認 #line 指令的結果跟在通常序列后。
示例
下面的示例說明調試器如何忽略代碼中的隱藏行。運行此示例時,它將顯示三行文本。但是,當設置如示例所示的斷點并按 F10 鍵逐句通過代碼時,您將看到調試器忽略了隱藏行。還請注意,即使在隱藏行上設置斷點,調試器仍會忽略它。
在日常開發的過程中我們總是會經常對代碼進行編譯,而在編譯的過程中會出現許多信息,許多無用的警告信息總是會在便一點過程中提示出來,以干擾一些主要的警告,對此也是可以通過預處理器指令來進行關閉來阻止其顯示,常見的警告如下(CS0219、CS0681等):
看一個例子:
[Obsolete("過期了",false)]
public static void aa()
{
}
static void Main()
{
int t=5; //警告:t已賦值,但其值從未使用
aa(); //警告:過期了
}
}
注意:我所使用的是vs2010如果多次編譯會自動將警告去除,如希望確保警告在輸出中被顯示,可以為項目做下清理:
清理的作用就是將之前在bin目錄中的程序集文件刪除
如果我們希望不顯示上圖紅框內的警告,我們可以用#pragma warning 指令來消除這些警告
在之前代碼上添加預處理指令:
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的作用是:用于給編輯器提供特殊的指令,說明如何編譯包含雜注的文件。
新聞熱點
疑難解答