xcode反汇编调试iOS模拟器程序(七)Debug与Release的区别

简介: 首先自己写一段代码,加好断点,分别在Build Configuration为Debug和Release下运行,查看反汇编 - (void)test{ UIButton *button = [[UIButton alloc] initWithFrame:CGRectMake(10.

首先自己写一段代码,加好断点,分别在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版都是立即数。反汇编中会把float所占的4字节空间的值显示为十进制数,需要自行转换实际的值,转换方法参见http://blog.csdn.net/hursing/article/details/8688862

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

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

这样的区别还有很多,可通过反汇编自己的代码来观察到。当调试进入系统的代码时,可以看出都是release版的,即debug版链接的仍是release版的静态库。


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

目录
相关文章
|
6月前
|
jenkins Unix 持续交付
个人记录jenkins编译ios过程 xcode是9.4.1
个人记录jenkins编译ios过程 xcode是9.4.1
93 2
|
6月前
|
存储 运维 安全
iOS加固原理与常见措施:保护移动应用程序安全的利器
iOS加固原理与常见措施:保护移动应用程序安全的利器
91 0
|
3月前
|
iOS开发 MacOS Perl
解决Xcode运行IOS报错:redefinition of module ‘Firebase‘和could not build module ‘CoreFoundation‘
解决Xcode运行IOS报错:redefinition of module ‘Firebase‘和could not build module ‘CoreFoundation‘
139 4
|
3月前
|
iOS开发 开发者
解决xcode doesn‘t support iphone’s ios 14.6 (18f72)
解决xcode doesn‘t support iphone’s ios 14.6 (18f72)
263 3
|
3月前
|
缓存 iOS开发
如何在Xcode删除某个版本的IOS模拟器
如何在Xcode删除某个版本的IOS模拟器
593 1
|
3月前
|
iOS开发
mac不通过Xcode直接打开IOS模拟器
mac不通过Xcode直接打开IOS模拟器
227 2
|
5月前
|
iOS开发
技术好文:xcode动态图,ios实现动态图,iosgif,暂停和继续播放
技术好文:xcode动态图,ios实现动态图,iosgif,暂停和继续播放
52 1
|
6月前
|
存储 定位技术 iOS开发
XCode8升级到Xcode9(操作系统为iOS11)后原来的工程中遇到的问题
XCode8升级到Xcode9(操作系统为iOS11)后原来的工程中遇到的问题
105 0
|
6月前
|
iOS开发
iOS之使用模拟器报错:resource fork, Finder information, or similar detritus not allowed完美解决方案
iOS之使用模拟器报错:resource fork, Finder information, or similar detritus not allowed完美解决方案
145 0
|
6月前
|
Linux 数据安全/隐私保护 iOS开发
Xcode8.1如何支持iOS8.0以下版本
Xcode8.1如何支持iOS8.0以下版本
45 0