从IL看时间换空间的思想

最近在研究IL,发现一个奇怪的现象,代码说明如下:

方法一:

ContractedBlock.gif ExpandedBlockStart.gif Code
        static void TestString(string s)
        {
            Console.WriteLine(s);
        }

方法二:

ContractedBlock.gif ExpandedBlockStart.gif Code
static void TestString2(string s)
        {
            
string str = s;
            Console.WriteLine(str);

        }

方法一的IL:

ContractedBlock.gif ExpandedBlockStart.gif Code
.method private hidebysig static void  TestString(string s) cil managed
{
  
// Code size       9 (0x9)
  .maxstack  8
  IL_0000:  nop
  IL_0001:  ldarg.
0
  IL_0002:  call       
void [mscorlib]System.Console::WriteLine(string)
  IL_0007:  nop
  IL_0008:  ret
// end of method Program::TestString

方法二的IL:

ContractedBlock.gif ExpandedBlockStart.gif Code
.method private hidebysig static void  TestString2(string s) cil managed
{
  
// Code size       11 (0xb)
  .maxstack  1
  .locals init ([
0string str)
  IL_0000:  nop
  IL_0001:  ldarg.
0
  IL_0002:  stloc.
0
  IL_0003:  ldloc.
0
  IL_0004:  call       
void [mscorlib]System.Console::WriteLine(string)
  IL_0009:  nop
  IL_000a:  ret
// end of method Program::TestString2

方法一的最大栈是8,方法二的最大栈是1,很明显, 方法二的IL行数比方法一多,且两个方法基本执行了相同的命令,按理说方法二的CLR编译并执行的时间更长,但最大栈数却比方法一少。这难道是IL的以时间换空间思想?

注:经测试,两个方法的实际执行时间基本相同。

转载于:https://www.cnblogs.com/liangxiaowu/archive/2008/11/25/1340889.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值