开发者社区 问答 正文

在汇编层面,模拟两次返回操作是如何实现的?

在汇编层面,模拟两次返回操作是如何实现的?

展开
收起
夹心789 2024-06-27 12:04:36 32 分享 版权
1 条回答
写回答
取消 提交回答
  • 在汇编层面,模拟两次返回操作是通过恢复fp和lr寄存器、恢复callee-saved寄存器、恢复sp寄存器以及执行ret指令来实现的。具体地,当tryLock失败时,首先恢复当前帧的fp和lr寄存器以及callee-saved寄存器,然后恢复sp寄存器并执行ret指令返回到-[UIKeyboardTaskQueue continueExecutionOnMainThread]方法的下一条指令;接着再次恢复fp和lr寄存器、callee-saved寄存器和sp寄存器,并执行ret指令返回到-[UIKeyboardTaskQueue continueExecutionOnMainThread]方法的上一层函数栈。

    2024-06-27 13:30:20
    赞同 1 展开评论
问答标签:
问答地址: