iOS美团同款"ZSource"二进制调试实现

Github开源地址,一步步教你使用

一、前言

前段时间我们项目也实现了组件的二进制化,在之前的技术周会中我们有提到跟美团同款ZSource的二进制调试能力,我们也在自己的Cocoapods-imy-bin插件上实现了相同的功能pod bin code,借助这个周会我们就再来一探究竟二进制是怎么实现调试的和插件pod bin code实现细节。

二、效果演示

image

三、原理

用 MachOViewer 来查看二进制文件,以获取到更友好的二进制信息。利用 MachOViewer,我们可以看到 “__debug_str” Section 这些信息都存在了二进制的中。__debug_str在编译的时候内部会记录源码地址

image

使用命令在终端输入:

dwarfdump ./libIMYNews.a | grep 'IMYNewsRootViewController'

一个DW_AT_name属性,其值是一个以空字符结尾的字符串,其中包含从其派生编译单元的主源文件的完整或相对路径名。

一个DW_AT_comp_dir属性,其值是一个以空值结尾的字符串,其中包含编译命令的当前工作目录,该编译命令以某种形式将Forelax视为主机系统,从而生成此编译单元。

换个通俗易懂的话说,二进制文件中记录了改源码文件对应的存放地址,IMYButton.m源文件存在在这个地址下

/Users/ci/.jenkins/workspace/Meetyou_Dev-build-temp/bin-archive/Seeyou/IMYNews/IMYNews/Source/IMYNewsRootView/Controller/IMYNewsRootViewController.h

而这个地址是什么呢? 其实就是我们制作二进制包时,该工程所属的文件地址。

image

Debug调试的时候,编译器会先从这里拿对应映射地址去加载源码文件。如果存在对应地址存在源码文件时,就能进入源码调试。

如果不想暴露这个调试信息呢?在build Settings 里面搜索 Generate Debug Symbols设置为No,可以将 __debug_str 字段都给去掉。

image

四、实验

这里可能有的同学就会疑惑,你这样的调试信息跟我们平时的Debug调试会不会有区别,不够准确?

实验一、Xcode源码运行的调试

现在我们就来做个实验,看看平时Debug调试是怎么样的。

  1. 先正常使用源码运行,在某一行下个断点,看看正常的调试情况
  2. 把当前断点的所在文件目录重命名为其他路径
  3. 再运行到断点的地方试试,是否还能像步骤1一样进入源码调试断点?(显然不行)
  4. 再把步骤2重命名的目录改回去,再Control+F7运行,这回又正常了。

在程序运行起来后,我们修改Pods库下的目录,等再次进入断点调试的时候,原理Xcode的源码调试突然变成了让人看不懂的汇编了,完全看不懂,看不懂。等你再次把目录修改回来后,又是你熟悉的那个Xcode。

即使是源码运行,调试的时候xcode也是根据我们的那套原理来的。

实验二、 Generate Debug Symbols设置为No

在源码运行的情况下,我把 IMYNews这个模块Generate Debug Symbols设置为No,后面不管再怎么使劲,断点也进不去

五、源码调试Cocoapods插件的实现

通过上面的原理分析我们知道,只要存在二进制静态库记录源码对应的文件就可以进入断点调试,但是Pods仓库是源码在远程怎么调试呢? 如何知道我当前运行的静态库对应哪个版本的源码呢?

image-20200701155401121.png


image

熟悉了Cocoapods一些原理后,找出依赖库代码就这几行。

#找出依赖
def find_dependency (name)
    find_dependency = nil
    @config.podfile.dependencies.each do |dependency|
    if dependency.root_name.downcase == name.downcase
      find_dependency = dependency
          break
      end
     end
     find_dependency
 end

# 获取external_source 下的仓库
# @return spec
def fetch_external_source(dependency ,podfile , lockfile, sandbox,use_lockfile_options)
          source =          ExternalSources.from_dependency(dependency, podfile.defined_in_file, true)
          source.fetch(sandbox)
end

下载对应源码

#下载源码到本地
def download_source(name)
  target_path =  File.join(source_root, name)
  UI.puts target_path
  FileUtils.rm_rf(target_path)
  
  find_dependency = find_dependency(name)
  spec = fetch_external_source(find_dependency, @config.podfile,@config.lockfile, @config.sandbox,true )
  download_request = Pod::Downloader::Request.new(:name => name, :spec => spec)
  Downloader.download(download_request, Pathname.new(target_path), :can_cache => true)

  target_path
end

创建软链接

ln -s target_path dir

六、最后:

有些东西就像变魔术一样,台下看得云里雾里的,实际上点破之后,会有总感觉,原来就是这么简单哈~。

七、参考文献

iOS Xcode 的汇编模式切换

美团 iOS 工程 zsource 命令背后的那些事儿

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 161,601评论 4 369
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,367评论 1 305
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 111,249评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,539评论 0 217
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,967评论 3 295
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,929评论 1 224
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,098评论 2 317
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,825评论 0 207
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,609评论 1 249
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,796评论 2 253
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,282评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,603评论 3 261
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,277评论 3 242
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,159评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,959评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,079评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,874评论 2 277