解决iOS第三方SDK之间重复的symbols问题


前言:今天公司项目准备使用高德导航,其中用到了高德3D地图SDK,然后就出现bug了。在真机上可以完美运行,但是在模拟器上,就出现了一大片的bug:提示有82个Duplicate symbols,仔细一看是MobileVLCKit和高德的MAMapKit之间的问题。(PS:今天是真心累啊,不过解决了bug,还是很值得的。)


现在,我就今天踩过的坑,做个简单的整理,以备以后翻看。 也希望以后遇到类似坑的小伙伴们,可以有些许启发和不同见解。


问题描述及猜想


duplicate symbols.png

上图为部分报错内容。两个第三方SDK之间在某些特定平台存在一些duplicate symbols。分析:那是不是除掉其中一个SDK中相应平台上,重复的那部分symbols,是不是就解决问题了呢?且继续向下看。


解决问题


通过查找资料,各种扒论坛,终于发现,跟我一起踩坑的小伙伴们还真不少。
然后通过借鉴他们的经验,在对linux的相关语法实在小白的情况下,终于解决问题了,好感动啊!!!


工具介绍


lipo

lipo是管理Fat File的工具, 可以查看平台列表, 提取特定平台, 重新打包。

nm

nm用来显示一个程序包的符号表, 默认会显示入口地址, 符号类型, 符号名。

strip

strip用来删除程序里的符号表。-R 用来指定一个要删除的符号列表, 使用上述生成的symbols文件.。添加 -S 选项来保留其他符号。

ar

ar可以查看一个程序包里的对象文件列表, 解压出其中的对象文件并重新打包。

ld

ld苹果系统下的链接器, 可以更精确的控制符号表的导出。


具体步骤


因为担心修改MobileVLCKit对已上线的视频播放造成不可估计的影响,因此,此次修改MAMapKit,出现任何bug也可以尽快发现并解决。
下面将进行十分小白式的记录(PS:主要是我太小白了。)

cd path(framework的路径)
lipo -info MAMapKit
lipo info MAMapKit

查看MAMapKit的适用平台,可以发现arm7,i386,x86_64,arm64均可用。并且前面bug只是存在于x86_64平台上,那么就先修改这个平台的内容。

 lipo -thin x86_64 MAMapKit -output MAMapKit.x86_64

文件瘦身,提取x86_64平台的MAMapKit到新的文件MAMapKit.x86_64,发现该文件只有3M而已(源文件20.2M),该文件位置与MAMapKit相同,发现确实单个平台的文件比较小。

nm -j MAMapKit.x86_64  | grep png > symbols
  • 获取MAMapKit.x86_64文件中以_png为前缀的所有符号,生成符号列表并存于symbols文件中。( -j 选项控制只输出符号名)

  • 因为上面的symbols内容不是上述bug中包含的内容,因此,需要更改该symbols文件,删除里面所有符号,将报错的所有重复符号

_png_do_invert
_png_set_shift
_png_get_user_transfom_ptr
...

这些符号依次输入到该文件中,每行一个。这就将本次需要删除的符号存在符号列表中了。

ar -t MAMapKit.x86_64
ar -t MAMapKit.x86_64

可以发现整个包中就一个主要文件MAMapKit-x86_64-master.o文件,这也是前面bug中提到的重名符号所在的位置。(PS:更确定找对了方法)

Duplicate symbols path
ar -x MAMapKit.x86_64
MAMapKit.x86_64 File Path

可以发现多出了三个文件,也获得了需要的MAMapKit-86_64-master.o文件。

ld -x -r -unexported_symbols_list symbols MAMapKit-x86_64-master.o -o MAMapKit-x86_64-master.o.strip

可以将symbols文件中的符号列表在MAMapKit-x86_64-master.o文件中删除掉,并生成一个新的文件MAMapKit-x86_64-master.o.strip。

ar -r MAMapKit.x86_64 MAMapKit-x86_64-master.o.strip Pods-MAMapKit-dummy.o
  • 在执行此命令之前,可以将前面获得MAMapKit.x86_64文件放在其他位置作为对比。
  • 然后通过该命令得到一个新打包好的x86_64平台包。
  • 也可以用以前的获取symbols的方式从这个新包中获取相应的_png的所有符号表,查询刚才需要删除的符号,验证那些符号是否已被删除。(很高兴确实已经删除了,这下问题应该可以解决了吧。)

下面将替换原有包中的x86_64平台包。(该文件中只修改了x86_64平台的内容)

lipo MAMapKit -replace x86_64 MAMapKit.x86_64 -output MAMapKitTest

用上面生成的新包替换MAMapKit包中的x86_64平台包,然后生成一个新的文件包,最后将旧的MAMapKit包移除,其他多余内容也一并移除,将MAMapKitTest更名为MAMapKit。至此,MAMapKit.framework看起来跟原来的没有什么区别了。(看事情不能只看表面哦,咱修改的是内在!)

多余的话:如果修改多个平台的包(因为我只需要修改x86_64这一个平台包),可能需要重新生成一个新包更合适。

  • 根据前面的方法,生成每个平台的新包;
  • 将所有新包对应各个平台,生成一个新包。
合成新包

上图红色标记即最后的合成新包方法。在此之前记得将前面更改过的x86_64平台包拷贝到这些包的相同路径下。

最后重新编译工程,就这么完美解决了!!!这一刻的感觉,太激动了。暂时未发现有什么问题,以后有什么由此衍生的bug,到时候再更新了。也希望小伙伴们共同学习,有问题大家一定要指出来哟!欢迎大家找我交流问题一起进步哦。


感谢下面两位大神踩过的坑,有了它们的经验,才让我如此顺利的解决问题!
[1]Mac系统下lipo, ar, nm等工具的使用简介
[2]Lipo - 如何为ARMv7/ARMv7s/ARM64架构 创建通用文件(Universal Files)](http://blog.csdn.net/volvet/article/details/50097563)

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

推荐阅读更多精彩内容