解决iOS第三方SDK之间重复的symbols问题
前言:今天公司项目准备使用高德导航,其中用到了高德3D地图SDK,然后就出现bug了。在真机上可以完美运行,但是在模拟器上,就出现了一大片的bug:提示有82个Duplicate symbols,仔细一看是MobileVLCKit和高德的MAMapKit之间的问题。(PS:今天是真心累啊,不过解决了bug,还是很值得的。)
现在,我就今天踩过的坑,做个简单的整理,以备以后翻看。 也希望以后遇到类似坑的小伙伴们,可以有些许启发和不同见解。
问题描述及猜想
上图为部分报错内容。两个第三方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
查看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
可以发现整个包中就一个主要文件MAMapKit-x86_64-master.o文件,这也是前面bug中提到的重名符号所在的位置。(PS:更确定找对了方法)
ar -x MAMapKit.x86_64
可以发现多出了三个文件,也获得了需要的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)
转载:http://www.jianshu.com/p/e857730015cf
解决iOS第三方SDK之间重复的symbols问题的更多相关文章
- unity 引入 ios 第三方sdk
原地址:http://blog.csdn.net/u012085988/article/details/17785023 unity开发中ios应用时,要想成功引入第三方sdk,首先得知道c#与obj ...
- 最受欢迎的iOS第三方SDK
http://www.raywenderlich.com/forums/viewtopic.php?t=4496
- iOS 第三方库冲突的处理
最近项目组在做一些第三方功能的集成,不止一次的遇到第三方库冲突的问题,报错如下: duplicate symbol _OBJC_METACLASS_$_JKSerializer in: /Users/ ...
- fir.im Weekly - 热门 iOS 第三方库大盘点
本期 fir.im Weekly 收集的热度资源,大部分关于Android.iOS 开发工具.源码和脑洞大开的 UI 动画,希望给你带来更多的工作创意与灵感. 盘点国内程序员不常用的热门iOS第三方库 ...
- Android高效率编码-第三方SDK详解系列(三)——JPush推送牵扯出来的江湖恩怨,XMPP实现推送,自定义客户端推送
Android高效率编码-第三方SDK详解系列(三)--JPush推送牵扯出来的江湖恩怨,XMPP实现推送,自定义客户端推送 很久没有更新第三方SDK这个系列了,所以更新一下这几天工作中使用到的推送, ...
- iOS 第三方库、插件、知名博客总结
iOS 第三方库.插件.知名博客总结 用到的组件 1.通过CocoaPods安装 项目名称 项目信息 AFNetworking 网络请求组件 FMDB 本地数据库组件 SDWebImage 多个缩略图 ...
- 开发者所需要知道的 iOS 10 SDK 新特性
转自:https://onevcat.com/2016/06/ios-10-sdk/ 写的很好啊.哈哈哈 总览 距离 iPhone 横空出世已经过去了 9 个年头,iOS 的版本号也跨入了两位数.在我 ...
- Unity导出xcode后自动化导入第三方SDK
最近因为在给项目接入第三方SDK,遇到了一个比较烦人的事情就是,每次出包都要重新根据第三方SDK说明设置xcode,每次最少花20分钟来设置,如果出错的话就不一定是20分钟的事了,所以我决定要做一个自 ...
- cocos2d-x + Lua接入iOS原生SDK的实现方案[转]
相信很多朋友在使用cocos2d-x+lua开发游戏时都遇到过接入iOS原生SDK的问题,比如常见的接应用内支付SDK,广告SDK或是一些社交平台SDK等等,我也没少接过这类SDK.这篇文章主要是对我 ...
随机推荐
- 给 layui upload 带每个文件的进度条, .net 后台代码
1.upload.js 扩展 功能利用ajax的xhr属性实现该功能修改过modules中的upload.js文件功能具体实现:在js文件中添加监听函数 //创建监听函数 var xhrOnProgr ...
- 理解git的分支原理,更好地使用git
文章内容转载于git-scm. 部分内容涉嫌枯燥 一.git分支概念 几乎每一种版本控制系统都以某种形式支持分支.使用分支意味着你可以从开发主线上分离开来,然后在不影响主线的同时继续工作.在很多版本控 ...
- python win32api 如何用代码模拟点击网页confirm框的确定按钮
mshtml.IHTMLDocument2 doc = (mshtml.IHTMLDocument2)webBrowser1.Document.DomDocument; doc.parentWindo ...
- mysql / sqlserver / oracle 常见数据库分页
空闲时间里用着mysql学习开发测试平台和测试用具, 在公司里将可用的测试平台部署,将数据库换成sqlserver 巴望着能去用oracle的公司 mysql中的分页 limit是mysql的语法se ...
- tomcat热部署.class
本人是在维护公司系统时遇到的问题,由于公司的系统是部署到客户服务器上,而系统中存在的问题又比较多,需要经常维护.如果每次修改完class文件后都需要去重启服务器, 那会给用户的使用造成不便,所以需要使 ...
- XML简单入门
1.xml文件的第一句为<?xml version="1.0" ?> xml 1.0版本和1.1版本有较大不同,且1.1版本向下不可兼容,故使用version 1.0 ...
- hdu-5707-Combine String
题意:给你三个字符串,让你计算1 2 串和3 串是否匹配,就是3串可以分解为 1 2 串,字母顺序必须是按照1 2 串的字母前后顺序. DP代码太深奥 看不太透,这个代码比较好理解一点: #incl ...
- ado_基本连接操作【四】
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Data. ...
- spring aop通过注解实现日志记录
首先是几个概念:连接点(Joinpoint).切点(Pointcut).增强(Advice).切面(Aspect) 另外也要使用到注解. 需求:通过注解定义LogEnable.然后程序运行能够识别定义 ...
- Birdman Quotes
Popularity is the slutty little cousin of prestige (威望,声望) . A man becomes a critic when he cannot b ...