zoukankan      html  css  js  c++  java
  • xcode反汇编调试iOS模拟器程序(七)Debug与Release的区别

    首先自己写一段代码,加好断点,分别在Build Configuration为Debug和Release下运行,查看反汇编

    - (void)test
    {
        UIButton *button = [[UIButton alloc] initWithFrame:CGRectMake(10.0, 20.0f, 30.1, 40)];
        [button setTitle:@"test" forState:UIControlStateNormal];
        [button setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
        [button addTarget:self action:@selector(buttonClicked:) forControlEvents:UIControlEventTouchUpInside];
        [self.view addSubview:button];
        [button release];
    }

    debug下的反汇编结果:

    0x6a10:  pushl  %ebp
    0x6a11:  movl   %esp, %ebp
    0x6a13:  pushl  %ebx
    0x6a14:  pushl  %edi
    0x6a15:  pushl  %esi
    0x6a16:  subl   $108, %esp
    0x6a19:  calll  0x6a1e                    ; -[ViewController test] + 14 at ViewController.mm:375
    0x6a1e:  popl   %eax
    0x6a1f:  movl   12(%ebp), %ecx
    0x6a22:  movl   8(%ebp), %edx
    0x6a25:  leal   -40(%ebp), %esi
    0x6a28:  movl   $10, %edi
    0x6a2d:  cvtsi2ss%edi, %xmm0
    0x6a31:  movl   $20, %edi
    0x6a36:  cvtsi2ss%edi, %xmm1
    0x6a3a:  movss  44642(%eax), %xmm2
    0x6a42:  movl   $40, %edi
    0x6a47:  cvtsi2ss%edi, %xmm3
    0x6a4b:  movl   %edx, -16(%ebp)
    0x6a4e:  movl   %ecx, -20(%ebp)
    0x6a51:  movl   57106(%eax), %ecx
    0x6a57:  movl   56146(%eax), %edx
    0x6a5d:  movl   %ecx, (%esp)
    0x6a60:  movl   %edx, 4(%esp)
    0x6a64:  movl   %eax, -44(%ebp)
    0x6a67:  movss  %xmm2, -48(%ebp)
    0x6a6c:  movss  %xmm3, -52(%ebp)
    0x6a71:  movl   %esi, -56(%ebp)
    0x6a74:  movss  %xmm0, -60(%ebp)
    0x6a79:  movss  %xmm1, -64(%ebp)
    0x6a7e:  calll  0xe56a                    ; symbol stub for: objc_msgSend
    0x6a83:  movl   -56(%ebp), %ecx
    0x6a86:  movl   %ecx, (%esp)
    0x6a89:  movss  -60(%ebp), %xmm0
    0x6a8e:  movss  %xmm0, 4(%esp)
    0x6a94:  movss  -64(%ebp), %xmm1
    0x6a99:  movss  %xmm1, 8(%esp)
    0x6a9f:  movss  -48(%ebp), %xmm2
    0x6aa4:  movss  %xmm2, 12(%esp)
    0x6aaa:  movss  -52(%ebp), %xmm3
    0x6aaf:  movss  %xmm3, 16(%esp)
    0x6ab5:  movl   %eax, -68(%ebp)
    0x6ab8:  calll  0x6900                    ; CGRectMake(float, float, float, float) at CGGeometry.h:269
    0x6abd:  subl   $4, %esp
    0x6ac0:  movl   $64, %eax
    0x6ac5:  movl   $0, %ecx
    0x6aca:  movl   -44(%ebp), %edx
    0x6acd:  leal   58762(%edx), %esi
    0x6ad3:  leal   -40(%ebp), %edi
    0x6ad6:  movl   56158(%edx), %ebx
    0x6adc:  movl   -68(%ebp), %edx
    0x6adf:  movl   %edx, (%esp)
    0x6ae2:  movl   %ebx, 4(%esp)
    0x6ae6:  movl   (%edi), %edx
    0x6ae8:  movl   %edx, 8(%esp)
    0x6aec:  movl   4(%edi), %edx
    0x6aef:  movl   %edx, 12(%esp)
    0x6af3:  movl   8(%edi), %edx
    0x6af6:  movl   %edx, 16(%esp)
    0x6afa:  movl   12(%edi), %edx
    0x6afd:  movl   %edx, 20(%esp)
    0x6b01:  movl   %eax, -72(%ebp)
    0x6b04:  movl   %ecx, -76(%ebp)
    0x6b07:  movl   %esi, -80(%ebp)
    0x6b0a:  calll  0xe56a                    ; symbol stub for: objc_msgSend
    0x6b0f:  movl   %eax, -24(%ebp)
    0x6b12:  movl   -24(%ebp), %eax
    0x6b15:  movl   -44(%ebp), %ecx
    0x6b18:  movl   56374(%ecx), %edx
    0x6b1e:  movl   %eax, (%esp)
    0x6b21:  movl   %edx, 4(%esp)
    0x6b25:  movl   -80(%ebp), %eax
    0x6b28:  movl   %eax, 8(%esp)
    0x6b2c:  movl   $0, 12(%esp)
    0x6b34:  calll  0xe56a                    ; symbol stub for: objc_msgSend
    0x6b39:  movl   -24(%ebp), %eax
    0x6b3c:  movl   -44(%ebp), %ecx
    0x6b3f:  movl   57074(%ecx), %edx
    0x6b45:  movl   56274(%ecx), %esi
    0x6b4b:  movl   %edx, (%esp)
    0x6b4e:  movl   %esi, 4(%esp)
    0x6b52:  movl   %eax, -84(%ebp)
    0x6b55:  calll  0xe56a                    ; symbol stub for: objc_msgSend
    0x6b5a:  movl   -44(%ebp), %ecx
    0x6b5d:  movl   56386(%ecx), %edx
    0x6b63:  movl   -84(%ebp), %esi
    0x6b66:  movl   %esi, (%esp)
    0x6b69:  movl   %edx, 4(%esp)
    0x6b6d:  movl   %eax, 8(%esp)
    0x6b71:  movl   $0, 12(%esp)
    0x6b79:  calll  0xe56a                    ; symbol stub for: objc_msgSend
    0x6b7e:  movl   -24(%ebp), %eax
    0x6b81:  movl   -16(%ebp), %ecx
    0x6b84:  movl   -44(%ebp), %edx
    0x6b87:  movl   56454(%edx), %esi
    0x6b8d:  movl   56394(%edx), %edi
    0x6b93:  movl   %eax, (%esp)
    0x6b96:  movl   %edi, 4(%esp)
    0x6b9a:  movl   %ecx, 8(%esp)
    0x6b9e:  movl   %esi, 12(%esp)
    0x6ba2:  movl   $64, 16(%esp)
    0x6baa:  calll  0xe56a                    ; symbol stub for: objc_msgSend
    0x6baf:  movl   -16(%ebp), %eax
    0x6bb2:  movl   -44(%ebp), %ecx
    0x6bb5:  movl   56350(%ecx), %edx
    0x6bbb:  movl   %eax, (%esp)
    0x6bbe:  movl   %edx, 4(%esp)
    0x6bc2:  calll  0xe56a                    ; symbol stub for: objc_msgSend
    0x6bc7:  movl   -24(%ebp), %ecx
    0x6bca:  movl   -44(%ebp), %edx
    0x6bcd:  movl   56354(%edx), %esi
    0x6bd3:  movl   %eax, (%esp)
    0x6bd6:  movl   %esi, 4(%esp)
    0x6bda:  movl   %ecx, 8(%esp)
    0x6bde:  calll  0xe56a                    ; symbol stub for: objc_msgSend
    0x6be3:  movl   -24(%ebp), %eax
    0x6be6:  movl   -44(%ebp), %ecx
    0x6be9:  movl   56138(%ecx), %edx
    0x6bef:  movl   %eax, (%esp)
    0x6bf2:  movl   %edx, 4(%esp)
    0x6bf6:  calll  0xe56a                    ; symbol stub for: objc_msgSend
    0x6bfb:  addl   $108, %esp
    0x6bfe:  popl   %esi
    0x6bff:  popl   %edi
    0x6c00:  popl   %ebx
    0x6c01:  popl   %ebp
    0x6c02:  ret    

    release下的反汇编结果:

    0x5310:  pushl  %ebp
    0x5311:  movl   %esp, %ebp
    0x5313:  pushl  %ebx
    0x5314:  pushl  %edi
    0x5315:  pushl  %esi
    0x5316:  subl   $44, %esp
    0x5319:  calll  0x531e                    ; -[ViewController test] + 14 at ViewController.mm:377
    0x531e:  popl   %edi
    0x531f:  movl   46610(%edi), %eax
    0x5325:  movl   45650(%edi), %ecx
    0x532b:  movl   %ecx, 4(%esp)
    0x532f:  movl   %eax, (%esp)
    0x5332:  calll  0xa78e                    ; symbol stub for: objc_msgSend
    0x5337:  movl   $1092616192, -32(%ebp)
    0x533e:  movl   $1101004800, -28(%ebp)
    0x5345:  movl   $1106300109, -24(%ebp)
    0x534c:  movl   $1109393408, -20(%ebp)
    0x5353:  movl   45662(%edi), %ecx
    0x5359:  movsd  -32(%ebp), %xmm0
    0x535e:  movsd  -24(%ebp), %xmm1
    0x5363:  movsd  %xmm1, 16(%esp)
    0x5369:  movsd  %xmm0, 8(%esp)
    0x536f:  movl   %ecx, 4(%esp)
    0x5373:  movl   %eax, (%esp)
    0x5376:  calll  0xa78e                    ; symbol stub for: objc_msgSend
    0x537b:  movl   %eax, %esi
    0x537d:  movl   45878(%edi), %eax
    0x5383:  leal   48262(%edi), %ecx
    0x5389:  movl   %ecx, 8(%esp)
    0x538d:  movl   %eax, 4(%esp)
    0x5391:  movl   %esi, (%esp)
    0x5394:  movl   $0, 12(%esp)
    0x539c:  calll  0xa78e                    ; symbol stub for: objc_msgSend
    0x53a1:  movl   46578(%edi), %eax
    0x53a7:  movl   45778(%edi), %ecx
    0x53ad:  movl   %ecx, 4(%esp)
    0x53b1:  movl   %eax, (%esp)
    0x53b4:  calll  0xa78e                    ; symbol stub for: objc_msgSend
    0x53b9:  movl   45890(%edi), %ecx
    0x53bf:  movl   %eax, 8(%esp)
    0x53c3:  movl   %ecx, 4(%esp)
    0x53c7:  movl   %esi, (%esp)
    0x53ca:  movl   $0, 12(%esp)
    0x53d2:  calll  0xa78e                    ; symbol stub for: objc_msgSend
    0x53d7:  movl   45898(%edi), %eax
    0x53dd:  movl   45958(%edi), %ecx
    0x53e3:  movl   %ecx, 12(%esp)
    0x53e7:  movl   8(%ebp), %ebx
    0x53ea:  movl   %ebx, 8(%esp)
    0x53ee:  movl   %eax, 4(%esp)
    0x53f2:  movl   %esi, (%esp)
    0x53f5:  movl   $64, 16(%esp)
    0x53fd:  calll  0xa78e                    ; symbol stub for: objc_msgSend
    0x5402:  movl   45854(%edi), %eax
    0x5408:  movl   %eax, 4(%esp)
    0x540c:  movl   %ebx, (%esp)
    0x540f:  calll  0xa78e                    ; symbol stub for: objc_msgSend
    0x5414:  movl   45858(%edi), %ecx
    0x541a:  movl   %esi, 8(%esp)
    0x541e:  movl   %ecx, 4(%esp)
    0x5422:  movl   %eax, (%esp)
    0x5425:  calll  0xa78e                    ; symbol stub for: objc_msgSend
    0x542a:  movl   45642(%edi), %eax
    0x5430:  movl   %eax, 4(%esp)
    0x5434:  movl   %esi, (%esp)
    0x5437:  calll  0xa78e                    ; symbol stub for: objc_msgSend
    0x543c:  addl   $44, %esp
    0x543f:  popl   %esi
    0x5440:  popl   %edi
    0x5441:  popl   %ebx
    0x5442:  popl   %ebp
    0x5443:  ret  

    单从行数上看,debug是127行,release是72行,差距很大。这当然是编译器优化的结果,特别对于一些分支多的、带循环的源码时,反汇编和源码的实际动作执行顺序都可能不同。

    可以看到:

    debug版在0x6ab8调用CGRectMake之前做了好多多余动作,往返访问xmm寄存器。debug版的浮点数,像30.1这样的数值才被真正当做浮点,10.0和20.0f都被当整数了。而release版都是立即数。反汇编中会把浮点数所占的4字节空间的值显示为十进制数,需要自行转换实际的值,转换方法参见http://blog.csdn.net/hursing/article/details/8688862

    CGRectMake的实质是个inline函数,在debug版还存在单独的函数代码入口位置,但release版就没有了。

    函数的开头表示debug版要用108字节作为局部变量空间,而release版只需要44字节。

    这样的区别还有很多,可通过反汇编自己的代码来观察到。


    转载请注明出处:http://blog.csdn.net/hursing

  • 相关阅读:
    HAProxy的基础配置详解
    Nginx七层负载均衡的几种调度算法
    基于PXE网络启动的Linux系统自动化安装
    centos源码编译安装新版本内核
    Linux计划任务管理
    Linux多网卡绑定(bond)及网络组(team)
    Linux逻辑卷管理(LVM)
    pandas基础操作
    subprocess
    python常用库(转)
  • 原文地址:https://www.cnblogs.com/xinyuyuanm/p/3003860.html
Copyright © 2011-2022 走看看