一个诡异的iOS bug

先交代下背景,

项目不同业务功能采用静待库依赖的方式,集成在主工程下。

最近接手了一块内部业务,做了整改。

一切都很顺利,

忽然测试说在iOS8的系统上一点业务的入口就会奔溃,每次必现,心中瞬间无数只草泥马。

怎么会这样呢? 

项目在10.3.2上跑起来是正常的,这太奇怪了,而且更诡异的是报错的地方连提示信息都没有。

从调用奔溃的函数调用堆栈可以看出

dyld:fastBindLazySymbol(ImageLoader**,unsigned long)

这是什么没有这个东西呀,查了资料,这是iOS对依赖的库进行链接和加载的时候系统会调用这个方法,那怎么会报这个错误呢?难道是我的lib项目在加载的时候出错了。

那为什么在10.3.2是好的,但8.0的版本会直接奔溃呢,经过一番思索和探究之后,

主工程的配置

静态库的配置

发现是我们项目的主工程最低支持的iOS版本是8.0,但我开发的那个lib库最小支持的版本是10.0的,

这就造成了主工程时8.0,项目可以装在我们的手机上,当点击了我们的模块入口时,发现版本不对,就直接奔溃了。

以上就是这次问题的原因。

随着项目迭代和业务模块的增加,模块化,静态库的依赖就势在必行了,但一定要注意我们主工程依赖的静态库支持的最低iOS的版本要低于或和我们主工程的支持的最低版本一致,要不然会造成一些奇异的奔溃问题。

以上内容希望能帮到一些遇到奔溃而又无从下手的人提供一种思路。

 

 

你可能感兴趣的:(iOS开发)