C#编译器或.NET运行时间如何处理逐字字符串文字与使用转义序列(即性能)有什么不同,还是只是设计时间风格?例如.:
var pathA = "c:\\somewhere"; var pathB = @"c:\somewhere";
我会想象他们是相同的编译,没关系,但只是好奇.
解决方法
这里的任何区别严格限制于编译器; IL和运行时没有逐字逐句的概念vs转义 – 它只是有字符串.
至于要选择哪一个:哪个更方便;如果有不寻常的字符,我几乎总是使用逐字字符串字面值,因为这样可以很容易地和视觉地使用多行字符串.
作为一个有趣的例子:
bool areSame = ReferenceEquals("c:\\somewhere",@"c:\somewhere"); // true
这告诉他们是完全相同的字符串实例(感谢“interning”).他们不只是等同的;它们是与运行时相同的字符串实例.因此,它们不可能(到运行时)以任何方式不同.