總結@ 在C# 中的用法

作者: 曉風殘月  來源: 博客園  發布時間: 2008-09-08 23:09  閱讀: 2725 次  推薦: 0   原文鏈接   [收藏]  
 
[1] 總結@ 在C# 中的用法
[2] 總結@ 在C# 中的用法

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

Code
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>";
// or
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)";

 

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

 

Code
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
My GOD!
如此編寫代碼,雖然提高了代碼的清晰度和簡便性,卻無行中帶來了另一個問題:字符長度!很多場景下我們希望字符串越短越好,如,通過ADO.NET 發送 SQL 語句給數據庫執行。
所以還是慎用之!

[第1頁][第2頁]
0
0
 
標簽:C#
 
 

文章列表

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()