先交代下背景,
项目不同业务功能采用静待库依赖的方式,集成在主工程下。
最近接手了一块内部业务,做了整改。
一切都很顺利,
忽然测试说在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的版本要低于或和我们主工程的支持的最低版本一致,要不然会造成一些奇异的奔溃问题。
以上内容希望能帮到一些遇到奔溃而又无从下手的人提供一种思路。