我有一个Resharper的试用版,它总是建议我将常规字符串切换为逐字字符串。有什么区别?
我有一个Resharper的试用版,它总是建议我将常规字符串切换为逐字字符串。有什么区别?
Answers:
逐字字符串是不需要转义的字符串,例如文件名:
string myFileName = "C:\\myfolder\\myfile.txt";
将是
string myFileName = @"C:\myfolder\myfile.txt";
@符号表示从字面上读取该字符串,否则不解释控制字符。
C#规范的第2.4.4.5节对此进行了介绍:
2.4.4.5字符串文字
C#支持两种形式的字符串文字:常规字符串文字和逐字字符串文字。
常规字符串文字由零个或多个用双引号引起来的字符组成,例如“ hello”,并且可以包括简单的转义序列(例如,制表符\ t)以及十六进制和Unicode转义序列。
逐字字符串文字包含一个@字符,后跟一个双引号字符,零个或多个字符以及一个结束的双引号字符。一个简单的例子是@“ hello”。在逐字字符串文字中,定界符之间的字符逐字解释,唯一的例外是引号-转义序列。特别是,简单的转义序列以及十六进制和Unicode转义序列不在逐字字符串文字中处理。逐字字符串文字可能跨越多行。
换句话说,@“ verbatim字符串文字”中唯一的特殊字符是双引号字符。如果要编写包含双引号的逐字字符串,则必须编写两个双引号。所有其他字符均按字面意义进行解释。
您甚至可以在逐字字符串文字中使用文字换行。在常规字符串文字中,不能有文字换行。相反,您必须使用例如"\n"
。
逐字字符串文字常用于在源代码中嵌入文件名和正则表达式,因为这些类型的字符串中的反斜杠很常见,如果使用常规字符串文字,则需要转义。
使用常规字符串文字创建的字符串和使用逐字字符串文字创建的字符串在运行时没有区别-它们都是类型System.String
。
字符串和逐字字符串之间没有运行时差异。它们只是在编译时有所不同。编译器在逐字字符串中接受较少的转义序列,因此,除了引号转义之外,您还能看到什么。
您还可以使用逐字字符@来告诉编译器将关键字视为名称:
var @if = "if";
//okay, treated as a name
Console.WriteLine(@if);
//compiler err, if without @ is a keyword
Console.WriteLine(if);
var @a = "a";
//okay
Console.WriteLine(@a);
//also okay, @ isn't part of the name
Console.WriteLine(a);
您也可以使用逐字字符串使用多行字符串:
Console.WriteLine(@"This
is
a
Test
for stackoverflow");
没有@
你的错误。
在VB14中有一个名为的新功能Multiline Strings
,就像C#中的逐字字符串一样。
专家提示:现在,VB字符串文字完全类似于C#逐字字符串。
常规字符串使用特殊的转义序列来转换为特殊字符。
/*
This string contains a newline
and a tab and an escaped backslash\
*/
Console.WriteLine("This string contains a newline\nand a tab\tand an escaped backslash\\");
逐字字符串按原样解释,不翻译任何转义序列:
/*
This string displays as is. No newlines\n, tabs\t or backslash-escapes\\.
*/
Console.WriteLine(@"This string displays as is. No newlines\n, tabs\t or backslash-escapes\\.");