OC 编译: symbol stub

本文探讨了应用程序如何通过符号打桩(symbolstub)与外部库交互,详细解释了在debug模式下,按住Ctrl时以汇编代码单步执行,不按Ctrl时以高级语言执行的过程。在外部函数调用中,桩代码指引执行路径,并在懒加载符号表中查找地址。首次执行外部函数会进行绑定,之后的执行则直接使用已绑定的地址。dyld_stub_binder在其中扮演关键角色,负责动态绑定。整个过程揭示了程序执行与系统库、三方库之间的紧密联系。

symbol stub

符号打桩


把我们的应用程序,

编译成汇编代码,

执行外部库的函数,

就成了跳转地址 ( symbol stub


debug, 按住 ctrl,

以汇编代码的语句,单步执行


debug, 没有按住 ctrl,

以高级语言的语句,单步执行


走外部函数,就会走外部函数的桩 ( stub )

桩里面的代码,

指向一个新的地址,是用来寻址的


走外部函数,先找到一个桩,

运行桩里面的代码,( 是一个偏移值 )

在懒加载符号表里面

( lazy Symbol Pointers )


懒加载符号表, Lazy Symbol Pointers

例如: Foundation 中的 NSLog


直接加载符号表, Non-Lazy Symbol Pointers

dyld_stub_binder

( 我只看见一个 )


指针在 arm 64 里面,占 8 个字节


外部函数 ( 系统库,三方库的执行 ),

  • 第一次执行,有一个绑定

  • 后来的执行,

绑定后,外部函数的地址,发生了改变


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值