c# – 逐字符串文字v转义序列

C#编译器或.NET运行时间如何处理逐字字符串文字与使用转义序列(即性能)有什么不同,还是只是设计时间风格?例如.:
var pathA = "c:\\somewhere";
var pathB = @"c:\somewhere";

我会想象他们是相同的编译,没关系,但只是好奇.

解决方法

这里的任何区别严格限制于编译器; IL和运行时没有逐字逐句的概念vs转义 – 它只是有字符串.

至于要选择哪一个:哪个更方便;如果有不寻常的字符,我几乎总是使用逐字字符串字面值,因为这样可以很容易地和视觉地使用多行字符串.

作为一个有趣的例子:

bool areSame = ReferenceEquals("c:\\somewhere",@"c:\somewhere"); // true

这告诉他们是完全相同的字符串实例(感谢“interning”).他们不只是等同的;它们是与运行时相同的字符串实例.因此,它们不可能(到运行时)以任何方式不同.

相关文章

原文地址:http://msdn.microsoft.com/en-us/magazine/cc163...
前言 随着近些年微服务的流行,有越来越多的开发者和团队所采...
最近因为比较忙,好久没有写博客了,这篇主要给大家分享一下...
在多核CPU在今天和不久的将来,计算机将拥有更多的内核,Mic...
c语言输入成绩怎么判断等级
字符型数据在内存中的存储形式是什么