为什么具有PEVerified Stack Overflow Scenario(maxstack)的程序不会崩溃CLR?

时间:2014-05-29 01:16:26

标签: clr stack-overflow cil peverify

我可以编写,编译并成功运行以下IL程序,其中.maxstack大小设置为1,这太低了,因为程序在一个时间点在堆栈上有两个值(即2 + 2 == 4) 。该程序中没有在CLR中崩溃,并以" Hello World"的所有预期输出完成执行。接着是4号。

然而,这个程序(正确地)不会传递PEVerify,它指出了堆栈溢出异常,并带有以下消息:

  

Microsoft(R).NET Framework PE Verifier。版本4.0.30319.18020   版权所有(c)Microsoft Corporation。保留所有权利。

     

[IL]:错误:[C:\ tmp \ hello.exe:HelloWorld1.Program :: Main] [偏移量   0x00000011]堆栈溢出。 1错误验证hello.exe

为什么它不会在CLR中崩溃?

.assembly extern mscorlib {}
.assembly SampleIL {
    .ver 1:0:1:0
}

.class private auto ansi beforefieldinit HelloWorld1.Program
    extends [mscorlib]System.Object
{
    // Methods
    .method private hidebysig static 
        void Main (
            string[] args
        ) cil managed 
    {
        // Method begins at RVA 0x2050
        // Code size 13 (0xd)
        .maxstack 1 // **** NOTE THIS LINE *****
        .entrypoint

        IL_0000: nop
        IL_0001: ldstr "hello world"
        IL_0006: call void [mscorlib]System.Console::WriteLine(string)
        IL_000b: nop

        ldc.i4 2
        ldc.i4 2
        add
        call void [mscorlib]System.Console::WriteLine(int32)

        IL_000c: ret
    } // end of method Program::Main

    .method public hidebysig specialname rtspecialname 
        instance void .ctor () cil managed 
    {
        // Method begins at RVA 0x205e
        // Code size 7 (0x7)
        .maxstack 8    

        IL_0000: ldarg.0
        IL_0001: call instance void [mscorlib]System.Object::.ctor()
        IL_0006: ret
    } // end of method Program::.ctor

} // end of class HelloWorld1.Program

1 个答案:

答案 0 :(得分:9)

通过@RaymondChen从问题评论中得出答案

公共语言基础结构(CLI)
分区III CIL指令集
最终草案,2005年4月

  

1.7.4必须提供maxstack

     

[...剪辑...]
  [注意: Maxstack与...有关   分析程序,而不是运行时堆栈的大小。它   没有指定堆栈帧的最大大小(以字节为单位),但是   而是分析工具应跟踪的项目数。   结束说明]