iOS解决重复引入三方库问题

随着项目开发往后走,引入的三方库、框架、SDK越来越多,难免会出现重复引入三方库的问题。特别是提供SDK的,他们可能很少会去考虑这个问题(ps:谁碰到谁去解决,我干嘛要操心这么久远的事情,跟我又没有什么关系,早点快速实现功能对外提供SDK完成任务才是当下应该做的)

这不,我就遇到这麽个怪异问题:

这里报错了四个同类型的错误,我们挖出其中一条看看:

objc[29729]: Class MJPropertyType is implemented in both /Users/llbt/Library/Developer/CoreSimulator/Devices/5FCC1CE9-D8FE-42DF-B562-623A629C01C4/data/Containers/Bundle/Application/5EAA459F-2C14-4DBB-8FD2-C433A318544C/release.app/Frameworks/MJExtension.framework/MJExtension (0x106c7a298) and /Users/llbt/Library/Developer/CoreSimulator/Devices/5FCC1CE9-D8FE-42DF-B562-623A629C01C4/data/Containers/Bundle/Application/5EAA459F-2C14-4DBB-8FD2-C433A318544C/release.app/release (0x10394d5a8). One of the two will be used. Which one is undefined.

翻译一下就是说类“MJPropertyType”在

/Users/llbt/Library/Developer/CoreSimulator/Devices/5FCC1CE9-D8FE-42DF-B562-623A629C01C4/data/Containers/Bundle/Application/5EAA459F-2C14-4DBB-8FD2-C433A318544C/release.app/Frameworks/MJExtension.framework/MJExtension 

/Users/llbt/Library/Developer/CoreSimulator/Devices/5FCC1CE9-D8FE-42DF-B562-623A629C01C4/data/Containers/Bundle/Application/5EAA459F-2C14-4DBB-8FD2-C433A318544C/release.app/release

中都实现了,它们中的一个将被使用,但是使用哪一个没有定义,是未知的。

我们先来看看MJPropertyType在哪里有定义:

首先我们去xcode的工程中搜索看看:

通过这一步,我们首先知道了MJPropertyType是三方库MJExtension中定义的类。

同时你也犯傻了对不对? 明明只有这一个地方引入了三方库MJExtension,为什么会说有两个地方有类MJPropertyType的实现代码呢?好,接着我们去终端下去看个究竟:

打开终端,进入项目根目录,执行如下语句搜索整个项目中指定字符串:

grep -rn "MJPropertyType" ./*

搜索结果中列出来的./Pods/目录下的行是因为Pods中引入了MJExtension,这个我们前面在Xcode中也搜索到了,此处不必关注。

重点是我用红色框起来的列在搜索结果最后面的那两行。这两行指向的是同一个SDK的不同版本,一个是生产正式版,一个是测试版

Binary file ./puhui/ThridLib/CCB/ProductionSDK/CCBCommunication.framework/CCBCommunication matches

意思是说CCBCommunication.framework/CCBCommunica二进制文件中匹配到了字符串“MJPropertyType”

我们可以通过otool命令查看更多信息:

终端下进入项目中CCBCommunication.framework目录下,执行如下命令查看CCBCommunication.framework包含的.o文件并过滤出带“MJ”字符的行:

otool -Lv CCBCommunication | grep MJ

.o文件是相应的源文件(.m)编译后的目标文件。

我们再对比下三方库MJExtension中的文件清单:

如果你有心情的话,可以一一数一下,MJExtension中每一个.m文件都对应了上面的一个.o文件。

至此,我们可以确认三方库MJExtension在主工程和SDK文件CCBCommunication.framework中分别被引入包含进来了。

在跑工程的时候,你会发现:即使MJPropertyType类在两个地方都有实现,但是并不妨碍App的运行。并且理论上应该是没有什么大问题的。因为不管系统选择使用哪个地方的类实现,其实现代码都是一样的,因为是同一个库。

不过此时没有问题,不代表永远没有问题。并且也只是理论上没问题,你不能保证潜在问题被扼杀。所以最好我们还是应该消除这个隐患!

解决方案:删除主工程中引入的MJExtension库的实现文件(.m文件),只留下.h文件

写过C程序的都知道,C程序从代码到可启动程序经历:

预处理-->编译(包含汇编)-->.o目标文件-->链接-->可执行文件

OC/Swift基于C,自然也是包含这套逻辑的。

一般来说,只要有符号(变量名、函数名)的声明(.h文件),那么从源码到编译为.o的目标文件这几个步骤是不会有问题的。如果声明的符号没有对应的定义或实现,那么链接就会通不过(静态链接通不过,动态链接编译可以通过但是运行时会出现加载不了的错误,关于链接,后面再写篇文章介绍)。

我这里主工程中对MJExtension库的引入是动态库的形式,所以报的错是运行时抛出来的,运行时在两个地方找到了同一个符号。所以我们的解决方案是删除主工程中引入的MJExtension库的实现文件。理由如下:

1. SDK中虽然也引入了,但是很明显我们不应该动别人的东西。

2. 保留主工程中引入的MJExtension的头文件,是为了编译的需要。

注意要删除所有的实现文件,不删除干净会报类似如下这样的错误:

这是因为MJExtension剩下的实现文件会参与编译,但是编译过程中引用到了被删除的那个文件定义的符号,所以就会报这种符号找不到的错误。

删除所有实现文件后主工程引入的MJExtension如下:

重新Command + R编译运行,不报错了...==> OK,完美解决!!!

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