免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開(kāi)通VIP
總結(jié) @ 在 C# string 中的用法

1。地球人都知道 C# 中 字符串常量可以以 @ 開(kāi)頭聲名,這樣的優(yōu)點(diǎn)是轉(zhuǎn)義序列“不”被處理,按“原樣”輸出,即我們不需要對(duì)轉(zhuǎn)義字符加上 \ (反斜扛),就可以輕松coding。如,

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

2。如要在一個(gè)用 @ 引起來(lái)的字符串中包括一個(gè)雙引號(hào),就需要使用兩對(duì)雙引號(hào)了。
這時(shí)候你不能使用 \ 來(lái)轉(zhuǎn)義爽引號(hào)了,因?yàn)樵谶@里 \ 的轉(zhuǎn)義用途已經(jīng)被 @  “屏蔽”掉了。如,

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

有點(diǎn)像SQL中的單引號(hào)常量處理方式:

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

3。@ 會(huì)識(shí)別換行符
其實(shí)這個(gè)特性,我不知道怎么描述,只是偶然發(fā)現(xiàn)的,先看下面的代碼吧:

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

安逸吧,在cs文件中寫js,結(jié)構(gòu)就很清晰了,正常情況我們是這樣coding的:

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

// or

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

通常我們會(huì)選擇后者,因?yàn)閖s代碼一般比較長(zhǎng),或者方法體很大,或者需要連接其他變量,這樣結(jié)構(gòu)比較清晰。

注意:如果“拼接”的次數(shù)很多,應(yīng)該考慮使用StringBuilder了,有助于提高性能。

還有一種場(chǎng)景,也很常見(jiàn),在程序中拼接 SQL 語(yǔ)句,如

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

哈哈,這樣就像寫存儲(chǔ)過(guò)程一般,保持相當(dāng)高的代碼清晰度。

然而我們需要關(guān)注一個(gè)問(wèn)題:字符串長(zhǎng)度

看下面的測(cè)試代碼:

        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
        }

可以看到三個(gè)字符串長(zhǎng)度分別相差了,14=126-112和26=112-86,注意觀察了,在代碼編輯器中,SQL_INS_USER1 中第一個(gè)換行符號(hào)之后,我縮進(jìn)13個(gè)空格(INSERT之前),而
SQL_INS_USER2 中第一個(gè)換行符號(hào)之后,我縮進(jìn)25個(gè)空格(VALUES之前),
那么,加上一個(gè)換行符,剛剛好 14和26

My GOD!

如此編寫代碼,雖然提高了代碼的清晰度和簡(jiǎn)便性,卻無(wú)行中帶來(lái)了另一個(gè)問(wèn)題:字符長(zhǎng)度!
很多場(chǎng)景下我們希望字符串越短越好,如,通過(guò)ADO.NET 發(fā)送 SQL 語(yǔ)句給數(shù)據(jù)庫(kù)執(zhí)行。
所以還是慎用之!
本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
Java入門到精通Java 15中的 3 個(gè)雙引號(hào)語(yǔ)法
SQL語(yǔ)句中的單引號(hào)處理以及模糊查詢
Python中如何進(jìn)行字符串定義?
php_正則表達(dá)式_歡歡和芳芳的天空
Py之re:re正則表達(dá)式庫(kù)的簡(jiǎn)介、入門、使用方法之詳細(xì)攻略
Python之re模塊
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服