C#中關於@的用法


之前一直沒有見過@出現在C#語句的字符串前的用法,這次去德瑞的面試題中第一次見到這種格式的,一下子沒反應過來,然后回來找了些資料,才知道原來@在帶轉義字符的字符串前面可以消除轉移字符的作用,所以今天雖然題做錯了,但也算是成長了。(以下內容摘自博客園)

C#中@的用法

1. 加在字符串前面,字符串中的 \ 失去轉義符的作用,直接寫字符串而不需要考慮轉義字符

C#代碼
  1. string path = @"C:\Windows\"; // 如果不加 @,編譯會提示無法識別的轉義序列
  2. // 如果不加 @,可以寫成如下
  3. string path2 = "C:\\Windows\\";
  1. string path = @"C:\Windows\"; // 如果不加 @,編譯會提示無法識別的轉義序列  
  2. // 如果不加 @,可以寫成如下  
  3. string path2 = "C:\\Windows\\";  

2. 加在字符串前面,字符串中的 " 要用 "" 表示

C#代碼
  1. string str = @"aaa=""bbb""";
  2. // 不加 @,可以寫成
  3. string str2 = "aaa=\"bbb\"";
  1. string str = @"aaa=""bbb""";  
  2. // 不加 @,可以寫成  
  3. string str2 = "aaa=\"bbb\"";  

3 加在字符串前面,換行空格都保存着,方便閱讀代碼

C#代碼
  1. string insert = @"
  2. insert into Users
  3. (
  4. UserID,
  5. Username,
  6. Email
  7. ) values
  8. (
  9. @UserID,
  10. @Username,
  11. @Email
  12. )";
  1. string insert = @"  
  2. insert into Users  
  3. (  
  4. UserID,  
  5. Username,  
  6. Email  
  7. ) values  
  8. (  
  9. @UserID,  
  10. @Username,  
  11. @Email  
  12. )";  

4 用關鍵字做變量時在關鍵字前面加@

C#代碼
  1. string @operator = "+";
  2. string @class = "分類一";
  3. Console.WriteLine(@operator);
  4. Console.WriteLine(@class);
  1. string @operator = "+";  
  2. string @class = "分類一";  
  3. Console.WriteLine(@operator);  
  4. Console.WriteLine(@class);  


5 作為sql語句里的一個“標簽”,聲明此處需要插入一個參數

C#代碼
    1. string delete = "delete from Categery where CategoryID=@CategoryID";
    2. SqlConnection connection = new SqlConnection("connectionString");
    3. SqlCommand command = new SqlCommand(delete, connection);
    4. command.Parameters.Add("@CategoryID", SqlDbType.BigInt);


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM