首页 > 移动平台 > 详细

iOS 为何使用runtime多次方法交换后却能按照交换顺序依次执行代码逻辑?

时间:2019-07-21 01:22:36      阅读:101      评论:0      收藏:0      [点我收藏+]

题目: 假设我们有一个ViewController, 

Category A(ViewController),

Category B(ViewController),

Category C(ViewController)

4个文件, 其中3个category中都实现了自定义viewDidLoad方法, 会对ViewController中的ViewDidLoad方法进行方法替换, 那么依次替换后(A B C)的方法执行顺序是什么呢?

记method_exchangeImplementations(Method _Nonnullm1, Method _Nonnullm2) 方法多次执行的代码执行逻辑.

1. IMP方法实现交换

第一趟: 交换 原方法 和 A 

技术分享图片

ViewController的原方法如下 

技术分享图片

在category A中方法如下: 

技术分享图片

交换后类实例方法和IMP的指向如下: 

技术分享图片

方法调用: 

交换后, 调用class 0(ViewController)的selector0, 会调用category A的IMP1, 既打印 “extension A viewDidLoad”, 然后调用了category A的Sel, 就会去执行 class 0(ViewController)的IMP, 既打印 “origin viewDidLoad method”;

控制台打印如下: 

技术分享图片

 接下来追加方法交换: 在原有方法交换基础上 追加 交换原方法 和 B 

技术分享图片

在category B中方法如下:  

技术分享图片

交换后类实例方法和IMP的指向如下: 

技术分享图片

代码执行: 执行Sel0—>IMP2—>SelB—>IMP1—>SelA—>IMP, 所以控制台输入顺序为 B A 0

控制台输出如下:

技术分享图片

 继续追加方法交换: 在原有方法交换基础上 追加 交换原方法 和 C 

技术分享图片

在category C中方法如下:  

技术分享图片

交换后类实例方法和IMP的指向如下: 

技术分享图片

代码执行: 先执行Sel0-->IMP3—>SelC—>IMP2—>SelB—>IMP1—>SelA—>IMP, 所以控制台输入顺序为 C B A 0

控制台输出如下: 

技术分享图片

由此可以推理出来: 

我们依次追加n个对原方法交换, 那么class 0对应的Sel0执行的IMP会偏移指向最后一个方法交换的Sel, 那么就会按照交换前后顺序执行逻辑.

Demo地址: https://github.com/Winerywine/MethodExchange.git

 

iOS 为何使用runtime多次方法交换后却能按照交换顺序依次执行代码逻辑?

原文:https://www.cnblogs.com/jgCho/p/11219936.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!