之前一直沒有見過@出現在C#語句的字符串前的用法,這次去德瑞的面試題中第一次見到這種格式的,一下子沒反應過來,然后回來找了些資料,才知道原來@在帶轉義字符的字符串前面可以消除轉移字符的作用,所以今天雖然題做錯了,但也算是成長了。(以下內容摘自博客園)
C#中@的用法
1. 加在字符串前面,字符串中的 \ 失去轉義符的作用,直接寫字符串而不需要考慮轉義字符
- string path = @"C:\Windows\"; // 如果不加 @,編譯會提示無法識別的轉義序列
- // 如果不加 @,可以寫成如下
- string path2 = "C:\\Windows\\";
- string path = @"C:\Windows\"; // 如果不加 @,編譯會提示無法識別的轉義序列
- // 如果不加 @,可以寫成如下
- string path2 = "C:\\Windows\\";
2. 加在字符串前面,字符串中的 " 要用 "" 表示
- string str = @"aaa=""bbb""";
- // 不加 @,可以寫成
- string str2 = "aaa=\"bbb\"";
- string str = @"aaa=""bbb""";
- // 不加 @,可以寫成
- string str2 = "aaa=\"bbb\"";
3 加在字符串前面,換行空格都保存着,方便閱讀代碼
- string insert = @"
- insert into Users
- (
- UserID,
- Username,
- ) values
- (
- @UserID,
- @Username,
- )";
- string insert = @"
- insert into Users
- (
- UserID,
- Username,
- ) values
- (
- @UserID,
- @Username,
- )";
4 用關鍵字做變量時在關鍵字前面加@
- string @operator = "+";
- string @class = "分類一";
- Console.WriteLine(@operator);
- Console.WriteLine(@class);
- string @operator = "+";
- string @class = "分類一";
- Console.WriteLine(@operator);
- Console.WriteLine(@class);
5 作為sql語句里的一個“標簽”,聲明此處需要插入一個參數
- string delete = "delete from Categery where CategoryID=@CategoryID";
- SqlConnection connection = new SqlConnection("connectionString");
- SqlCommand command = new SqlCommand(delete, connection);
- command.Parameters.Add("@CategoryID", SqlDbType.BigInt);