之前一直没有见过@出现在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);