Jon*_*eet 24
这取决于JIT(就我所知,C#编译器没有进行任何内联),但我相信JIT会在大多数情况下内联琐碎的属性.
请注意,它不会内联MarshalByRefObject包含System.Windows.Forms.Control(via System.ComponentModel.Component)的类型的成员.
我也看到double字段在通过属性访问时最终效率较低 - 可能是因为存在一些细微之处(由于寄存器使用等).
另请注意,64位和32位JIT是不同的,包括它们对内联的处理方式.
编辑:我刚刚发现David Notario 2004年的一篇博客文章,其中包含更多信息.然而,那是在2.0发货之前 - 我不会惊讶地发现现在至少有一些已经改变了.反正可能会引起人们的兴趣.
编辑:另一个问题涉及2008年Vance Morrison博客文章,它提供了更多信息.有趣的东西.
我花了一段时间才弄清楚在Visual Studio中你可以在JIT编译后查看托管代码的反汇编.
那么为什么不创建一个具有非常简单的访问器属性的类,在发布模式下运行它,设置一个断点,看看反汇编说的是什么?
我最近发布了一个类似的问题:
我的问题是公共字段比属性更快,因为我运行的是 64 位 Vista 并且 JIT 也将我的代码编译为 64 位,并且我的属性没有内联。强制项目针对 x86 进行编译确实内嵌了该属性,并且该属性与公共字段之间没有速度差异。
因此,C# 32 位 JIT 执行内联属性,而 64 位则不执行,任何其他非静态方法也不执行。
| 归档时间: |
|
| 查看次数: |
7658 次 |
| 最近记录: |