这是c#(或可能是VB.net)的.NET问题,但我试图弄清楚以下声明之间的区别:
string hello = "hello";
vs.
string hello_alias = @"hello";
在控制台上打印没有区别,长度属性是相同的。
这是c#(或可能是VB.net)的.NET问题,但我试图弄清楚以下声明之间的区别:
string hello = "hello";
vs.
string hello_alias = @"hello";
在控制台上打印没有区别,长度属性是相同的。
当前回答
既然你也明确地要求使用VB,让我补充一下,这种逐字逐句的字符串语法在VB中不存在,只在c#中存在。相反,在VB中,所有字符串都是逐字逐句的(除了它们不能包含换行符,不像c#逐字逐句的字符串):
Dim path = "C:\My\Path"
Dim message = "She said, ""Hello, beautiful world."""
VB中不存在转义序列(除了引号字符的加倍,就像c#中的逐字字符串一样),这使得一些事情更加复杂。例如,要在VB中编写以下代码,您需要使用连接(或任何其他构造字符串的方法)
string x = "Foo\nbar";
在VB中,这将被写成如下:
Dim x = "Foo" & Environment.NewLine & "bar"
(&是VB字符串连接操作符。+也可以同样使用。)
其他回答
它是一个逐字串字面量。这意味着转义没有被应用。例如:
string verbatim = @"foo\bar";
string regular = "foo\\bar";
这里逐字和逐字具有相同的内容。
它还允许多行内容——这对SQL来说非常方便:
string select = @"
SELECT Foo
FROM Bar
WHERE Name='Baz'";
对于逐字串字面量来说,一个必要的转义是获得一个双引号("),你可以通过将它加倍来做到:
string verbatim = @"He said, ""Would you like some coffee?"" and left.";
string regular = "He said, \"Would you like some coffee?\" and left.";
它将字符串标记为逐字串字面值——字符串中任何通常会被解释为转义序列的内容都将被忽略。
所以"C:\\Users\\Rich"和"C:\Users\Rich"是一样的
有一个例外:双引号需要转义序列。要转义双引号,需要在一行中放入两个双引号。例如,@""""的计算结果为“。
复制自MSDN:
在编译时,逐字字符串被转换为具有所有相同转义序列的普通字符串。因此,如果在调试器监视窗口中查看逐字字符串,将看到编译器添加的转义字符,而不是源代码中的逐字版本。例如,逐字字符串@"C:\files.txt"将以"C:\\files.txt"的形式出现在监视窗口中。
http://msdn.microsoft.com/en-us/library/aa691090.aspx
c#支持两种形式的字符串字面量:常规字符串字面量和逐字字符串字面量。
常规字符串文字由0个或多个用双引号括起来的字符组成,如"hello",并且可能包括简单转义序列(如制表符的\t)和十六进制和Unicode转义序列。
A verbatim string literal consists of an @ character followed by a double-quote character, zero or more characters, and a closing double-quote character. A simple example is @"hello". In a verbatim string literal, the characters between the delimiters are interpreted verbatim, the only exception being a quote-escape-sequence. In particular, simple escape sequences and hexadecimal and Unicode escape sequences are not processed in verbatim string literals. A verbatim string literal may span multiple lines.
这是一个逐字字符串,并更改转义规则-现在唯一被转义的字符是“,转义为“”。这对于文件路径和regex特别有用:
var path = @"c:\some\location";
var tsql = @"SELECT *
FROM FOO
WHERE Bar = 1";
var escaped = @"a "" b";
etc