以前一直没有见过@出如今C#语句的字符串前的用法,此次去德瑞的面试题中第一次见到这种格式的,一会儿没反应过来,而后回来找了些资料,才知道原来@在带转义字符的字符串前面能够消除转移字符的做用,因此今天虽然题作错了,但也算是成长了。(如下内容摘自博客园)面试
1. 加在字符串前面,字符串中的 \ 失去转义符的做用,直接写字符串而不须要考虑转义字符sql
- string path = @"C:\Windows\"; // 若是不加 @,编译会提示没法识别的转义序列
- // 若是不加 @,能够写成以下
- string path2 = "C:\\Windows\\";
- string path = @"C:\Windows\"; // 若是不加 @,编译会提示没法识别的转义序列
- // 若是不加 @,能够写成以下
- string path2 = "C:\\Windows\\";
2. 加在字符串前面,字符串中的 " 要用 "" 表示c#
- string str = @"aaa=""bbb""";
- // 不加 @,能够写成
- string str2 = "aaa=\"bbb\"";
- string str = @"aaa=""bbb""";
- // 不加 @,能够写成
- string str2 = "aaa=\"bbb\"";
3 加在字符串前面,换行空格都保存着,方便阅读代码ide
- string insert = @"
- insert into Users
- (
- UserID,
- Username,
- Email
- ) values
- (
- @UserID,
- @Username,
- @Email
- )";
- string insert = @"
- insert into Users
- (
- UserID,
- Username,
- Email
- ) values
- (
- @UserID,
- @Username,
- @Email
- )";
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);