- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有这个 CIL 代码序列,我通过使用 Mono.Cecil
注入(inject)了这些代码。但是,修改后的 .NET C# 应用程序将不会运行。
目标:手动从堆栈加载和弹出值以显示在 Console.WriteLine
for (int i = 0; i < 3; i++)
{
int z = some value popped manually from stack;
Console.WriteLine(z);
}
这是我修改的简单 main() 程序:
.method private hidebysig static void Main(string[] args) cil managed
{
.entrypoint
.maxstack 5
.locals init (
[0] int32 num,
[1] int32 num2)
L_0000: ldc.i4.6 //manually push value 6 to stack
L_0001: ldc.i4.5 //manually push value 5 to stack
L_0002: ldc.i4.4 //manually push value 4 to stack
L_0003: ldc.i4.0 //push int i initial value 0 to stack
L_0004: stloc.0 //pop and store to int i variable to variable num
L_0005: br.s L_0013
L_0007: nop
L_0008: stloc.1 //pop the pushed values 6,5 and 4 to variable num2
L_0009: ldloc.1 //load value of num2 to stack
L_000a: call void [mscorlib]System.Console::WriteLine(int32) //pop value of num2 and print
L_000f: ldloc.0 //load previous value in variable num to stack
L_0010: ldc.i4.1 //load incremental value 1 to stack
L_0011: add //pop and add the top 2 values, result is pushed to stack
L_0012: stloc.0 //store the new result to variable num. (int i)
L_0013: ldloc.0 //push int i variable value to stack
L_0014: ldc.i4.3 //push value 3 to stack as number of times to loop
L_0015: blt.s L_0007 //branch less than (pop and cmp the top 2 values in stack)
L_0017: ret
}
但是,上面的代码无法运行。我尝试将 blt.s
更改为 clt
和 br_true.s
但它也不起作用。有谁知道是否有可能实现我的目标?谢谢。
编辑:根据 ECMA-335,III.1.7.5,可能存在向后分支约束。不确定是否是这种情况。
In particular, if that single-pass analysis arrives at an instruction, call it location X, that immediately follows an unconditional branch, and where X is not the target of an earlier branch instruction, then the state of the evaluation stack at X, clearly, cannot be derived from existing information. In this case, the CLI demands that the evaluation stack at X be empty.
最佳答案
您的 IL 代码看起来不错,但我认为 CLR 可能无法在方法完成后检查堆栈是否已损坏。当某些东西被压入堆栈时,CLR 会检查该值是否也从堆栈中弹出。
因此,如果您将 3 个值压入堆栈,CLR 可能无法检查您的循环是否运行了三次,因此 CLR 不知道方法返回时堆栈上是否仍有值。
关于c# - 评估堆栈的 .NET CIL 操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12926476/
我正在查看 CIL 中的各种操作码,我发现了很多类似的代码,例如 Beq,Beq_S Bge,Bge_S Bgt,Bgt_S Br,Br_S 其中 S 应该是“短格式”。这意味着什么?? 最佳答案 指
查看 monodis 生成的代码,我看到对 Console.WriteLine 的调用被转换为 call void class [mscorlib]System.Console::WriteLine。
使用 Frama-C API 中定义的 Cil_datatypes 模块,我尝试用谓词 (Cil_datatype) 中的新术语替换术语 (Cil_datatype)。为此,我需要使用一个函数映射一个
由于各种原因,我正在学习 CIL,似乎类的定义通常类似于: .class public auto ansi beforefieldinit [...] extends [mscorlib]Syste
在 Microsoft IL 中,要对值类型调用方法,您需要间接引用。假设我们有一个名为“il”的 ILGenerator 并且当前我们在堆栈顶部有一个 Nullable,如果我们想检查它是否有值,那
让我们假设以下 CIL 程序: .assembly extern mscorlib {} .assembly Program {} .method private static void Main()
这可能是一个基本问题,但是CIL的含义是什么? 我知道CIL是与平台和CPU无关的中间语言,但是 有人对此进行了解释以及CPU不可知论的含义将对您有所帮助。 最佳答案 如果是platform agno
我对值类型和 CIL 评估堆栈有点困惑。 ECMA-335, Partition III, §1.1 说 CLI 处理这些“基本 CLI 类型”: A subset of the full numer
如果应用程序采用 MSIL 格式,为什么 Visual Studio 会将应用程序编译为可执行文件?不应该像java那样把代码编译成.class文件吗? 最佳答案 .NET“可执行文件”实际上是一个很
是否有任何可读的最新(.net 4)MSIL 引用手册? 最佳答案 有一堆可下载的引用文档here . 包括 2006 年 6 月的 ECMA-335 公共(public)语言基础结构文档 (pdf)
.Net 运行时是否对 CIL 指令的原子性做出任何保证?如果是这样,它们是什么?所有 CIL 指令都是原子的吗?或者它是否取决于 JIT 编译器生成的机器代码的原子性,因此太特定于平台而无法做出任何
我有一个基于自定义堆栈的语言,我正在尝试将其编译为 CIL,以便可以对其进行 JIT 编译。该语言本身相当简单,因为它只有整数和 bool 值。然而,每种数据类型都有一个专用的堆栈。该语言本身是一个命
假设我的解决方案中有一个 C# Windows 类库,我在 VS2010 IDE 中构建它。我的 bin 目录中的输出是 X.dll 1) X.dll现阶段不包含MSIL,而是“压缩字节码”。 这是真
是否有任何 .NET CIL(又名 MSIL)ANTLR 语法? 最佳答案 根据this publication , Microsoft 在Microsoft Visual Studio 安装文件as
什么是获得可移植可执行文件的良好、人类可读形式的 CLI 的好程序?我不想要一个完整的反汇编程序,因为我想了解它们的工作原理(或者,就我而言,不工作)。 最佳答案 我推荐reflector . 它可以
我可以将指令编译为字节码,甚至可以轻松执行它们,但我发现提取 CIL 的唯一函数是 GetILAsByteArray,顾名思义,它只返回字节而不是 CIL 指令。 那么如何在 .NET 上以编程方式反
我理解以下 C# 代码: var evens = from n in nums where n % 2 == 0 select n; 编译为: var evens = nums.Where(n =>
尝试使用 ildasm 深入研究 CIL 代码,很明显 CIL 本身正在基于堆栈工作以支持如下表达式 IL_0001: ldc.i4.s 13 ; 1f 0d IL_0003: s
我在 CIL 中定义了一个字段,如下所示: .field public int32 modopt(void*) fld 我把它编译成一个程序集。现在我把它改成: .field public int32
是否可以编写将任何类型(值和引用)的实例转换为 System.String 的通用 CIL 指令? 特别是,我对将这些指令注入(inject)方法的 Mono.Cecil 代码感兴趣。 分析一个通用方
我是一名优秀的程序员,十分优秀!