问题标签 [cil]
For questions regarding programming in ECMAScript (JavaScript/JS) and its various dialects/implementations (excluding ActionScript). Note JavaScript is NOT the same as Java! Please include all relevant tags on your question; e.g., [node.js], [jquery], [json], [reactjs], [angular], [ember.js], [vue.js], [typescript], [svelte], etc.
cil - MSIL 属性设置器 - 访问值字段
我有以下设置方法,但是我放入的对象value
没有传递给被调用的方法:
我想在L_000c
like中调用该函数Set(0x6c, ldfld MemoryAddress, value)
。前两个字段已正确发布到函数。有什么线索吗?当做类似的事情并查看 Reflector 中的定义时,它看起来相当不错。
.net - let_ 属性方法的好奇
每个 .net 开发人员都知道属性的概念。粗略的 99.99%,它只是将两个方法(getter 和 setter)粘合在一起的一段元数据。
同样的事情通常也适用于事件,包括它们的 add、remove 和 invoke 方法。
ECMA-335 描述了一种 «Other» 方法语义,适用于属性或事件。从概念上讲,一个属性或一个事件可以有多个“其他”方法。
今天是我第一次偶然发现一个带有“其他”方法的属性。当然,它必须与 COM 有关。EnvDTE 程序集(用于将插件写入 Visual Studio)中的接口 EnvDTE.Property 包含定义如下的属性:
将 let_Value 定义为:
显然,VBScript 和 VB.NET 之前的 VB 版本可以使用 Let 关键字定义属性。Let 与 Set 具有相同的签名。我感觉这里有关系。
但是有谁知道这个属性是如何用 EnvDTE 编写的语言声明的?如何创建具有相同模式的程序集(不使用 ilasm,这太容易了)?有没有人遇到过类似的财产?
有没有人见过其他的“其他”属性,可能与这个不同的语义?如果是,他们习惯什么?
.net - 操纵 .NET 字节码 - JIT 再生?
是否可以在运行时操纵(签名的).NET 程序的字节码?例如,通过强制 JIT 重新评估 IL?
linq - 紧凑框架的 ILASM?
我在 Compact Framework 上使用 Linq 表达式树(来自 db4o/Mainsoft/Mono 端口)。由于 System.Reflection.Emit 不存在,我无法将我的 LambdaExpressions 编译为委托,出于性能原因我想这样做。
我想也许我可以将我的表达式树转换为 IL 并基本上以这种方式提供缺少的 Emit 功能,但后来我意识到我必须在其上运行基于 WinCE 的 ILASM 或编写我自己的 PE 标头和汇编元数据。
我更希望 ILASM 可用。是吗?
.net - 为什么 .NET 代码编译为 MSIL?
首先 .NET 代码编译为 MSIL,然后 JIT 将其转换为机器相关代码。谁能告诉我由于两步编译而获得的所有好处。谢谢
c# - 有没有办法查看 JITter 为给定的 C#/CIL 生成的本机代码?
在对此答案的评论中(建议在整数乘法/除法上使用位移运算符,以提高性能),我质疑这实际上是否会更快。在我的脑海里有一个想法,在某种程度上,有些东西会足够聪明,可以解决这个问题,>> 1
并且/ 2
是相同的操作。但是,我现在想知道这是否真的是真的,如果是的话,它发生在什么级别。
optimize
测试程序为分别划分和移动其参数的两种方法生成以下比较 CIL (with on):
相对
所以 C# 编译器是在发出div
指令shr
,而不是聪明。我现在想看看 JITter 生成的实际 x86 汇编程序,但我不知道如何执行此操作。甚至可能吗?
编辑添加
发现
感谢您的回答,已接受来自 nobugz 的回答,因为它包含有关该调试器选项的关键信息。最终对我有用的是:
- 切换到发布配置
- 在
Tools | Options | Debugger
中,关闭“Suppress JIT optimization on module load”(即我们要允许JIT 优化) - 同一个地方,关闭“仅启用我的代码”(即我们要调试所有代码)
- 在
Debugger.Break()
某处发表声明 - 构建程序集
- 运行 .exe,当它中断时,使用现有的 VS 实例进行调试
- 现在 Disassembly 窗口显示了将要执行的实际 x86
结果至少可以说是很有启发性的——事实证明 JITter 实际上可以做算术!这是来自“反汇编”窗口的编辑示例。各种-Shifter
方法除以二的幂使用>>
;各种-Divider
方法除以整数使用/
两种静态除以 2 方法不仅被内联,而且实际计算已经由 JITter 完成
与静态除以 3 相同。
并静态除以 4。
最好的:
它是内联的,然后计算所有这些静态除法!
但是如果结果不是静态的呢?我添加了代码以从控制台读取整数。这就是它为以下部门产生的结果:
因此,尽管 CIL 不同,但 JITter 知道除以 2 是右移 1。
00000283 idiv eax,ecx
它知道你必须除以 3。
它知道除以 4 就是右移 2。
终于(又是最好的了!)
它根据静态可用的参数内联了方法并找出了做事的最佳方式。好的。
所以是的,在 C# 和 x86 之间的堆栈中的某个地方,有一些足够聪明的东西可以解决这个问题>> 1
并且/ 2
是相同的。所有这一切都让我更加重视我的观点,即把 C# 编译器、JITter 和 CLR 加在一起比我们作为谦逊的应用程序程序员可以尝试的任何小技巧更聪明:)
.net - 您将使用什么来为 .NET 构建新的编译器?
我正在研究一种新的玩具语言,它将被静态编译为 .NET 的 IL 代码。
我可以想到以下方法来实际生成 IL,但我对替代方案持开放态度:
- 塞西尔
- 国际法学会
antlr - CIL ANTLR 语法?
是否有任何 .NET CIL (AKA MSIL) ANTLR 语法?