C#中@用法的執行個體解析

來源:互聯網
上載者:User
本文執行個體匯總了C#中@的用法,對C#程式設計來說有不錯的借鑒價值。具體如下:

一 字串中的用法

1.學過C#的人都知道C# 中字串常量可以以@ 開頭聲名,這樣的優點是逸出序列“不”被處理,按“原樣”輸出,即我們不需要對逸出字元加上 \ (反斜扛),就可以輕鬆coding。如,

string filePath = @"c:\Docs\Source\a.txt" // rather than "c:\\Docs\\Source\\a.txt"

2.如要在一個用 @ 引起來的字串中包括一個雙引號,就需要使用兩對雙引號了。這時候你不能使用 \ 來轉義爽引號了,因為在這裡 \ 的轉義用途已經被 @ “屏蔽”掉了。如,

@"""Ahoy!"" cried the captain."  // 輸出為: "Ahoy!" cried the captain.

這有點像SQL中的單引號常量處理方式:

DECLARE @msg varchar(100) SET @msg = ''Ahoy!'' cried the captain.' -- 輸出為: 'Ahoy!' cried the captain.

3.@會識別分行符號

其實這個特性,我不知道怎麼描述,只是偶然發現的,先來看看下面的代碼:

string script = @" <script type=""type/javascript""> function doSomething() { } </script>";

這段代碼在cs檔案中寫js,結構就很清晰了,正常情況我們是這樣coding的:

string script2 = "<script type=\"type/javascript\">function doSomething(){}</script>";

或者:

string script3 = "<script type=\"type/javascript\">" + "function doSomething(){ " + "}</script>";

通常我們會選擇後者,因為js代碼一般比較長,或者方法體很大,或者需要串連其他變數,這樣結構比較清晰。

注意:如果“拼接”的次數很多,應該考慮使用StringBuilder了,有助於提高效能。

還有一種情境,也很常見,在程式中拼接 SQL 陳述式,如

private const string SQL_INS_USER = @" INSERT INTO t_User([UserName], [Password], Email)   VALUES(@UserName, @Password, @Email)";

這樣就像寫預存程序一般,保持相當高的代碼清晰度。然而,我們需要關注一個問題:字串長度看下面的測試代碼:

private const string SQL_INS_USER1 = @"   INSERT INTO t_User([UserName], [Password], Email)   VALUES(@UserName, @Password, @Email)"; private const string SQL_INS_USER2 = @"INSERT INTO t_User([UserName], [Password], Email)   VALUES(@UserName, @Password, @Email)"; private const string SQL_INS_USER3 = @"INSERT INTO t_User([UserName], [Password], Email) VALUES(@UserName, @Password, @Email)";  static void Main(string[] args) {   Console.WriteLine(SQL_INS_USER1.Length);  // 126    Console.WriteLine(SQL_INS_USER2.Length);  // 112   Console.WriteLine(SQL_INS_USER3.Length);  // 86 }

這裡可以看到三個字串長度分別相差了,14=126-112和26=112-86,注意觀察了,在代碼編輯器中,SQL_INS_USER1 中第一個分行符號號之後,我縮排13個空格(INSERT之前),而
SQL_INS_USER2 中第一個分行符號號之後,我縮排25個空格(VALUES之前),
那麼,加上一個分行符號,剛剛好 14和26

如此編寫代碼,雖然提高了代碼的清晰度和簡便性,卻無行中帶來了另一個問題:字元長度!
很多情境下我們希望字串越短越好,如,通過ADO.NET 發送 SQL 陳述式給資料庫執行。
所以還是慎用之!

二 標識符中的用法

在 C# 規範中, @ 可以作為標識符(類名、變數名、方法名等)的第一個字元,以允許C# 中保留關鍵字作為自己定義的標識符。

如下代碼:

class @class {   public static void @static(bool @bool) {    if (@bool)      System.Console.WriteLine("true");    else      System.Console.WriteLine("false");   }   } class Class1 {   static void M() {    cl\u0061ss.st\u0061tic(true);   } }

注意,@雖然出現在標識符中,但不作為標識符本身的一部分。
因此,以上樣本,定義了一個名為 class 的類,並包含一個名為 static 的方法,以及一個參數名為了 bool 的形參。

這樣,對於跨語言的移植帶來了便利。因為,某個單詞在 C# 中作為保留關鍵字,但是在其他語言中也許不是。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.