注意你的lib库的deployment target!

大家都知道一个应用的deploymenttarget是决定了应用所能工作的设备系统的最低版本,所以我们在设置该target的时候都设置成了项目所支持的系统最低版本(为了最大程度的兼容),如果设置的高了,在低版本的设备上是无法正常安装的,所以对于应用的deployment target的设置我们大家一般都不会犯错误。但是对于应用依赖于lib库时情况又有所不同:无论我们lib库所设置的deployment target是多少,这个lib都可以正常的被加载,工程也会顺利的通过编译,并且安装到设备上(决定能否安装到设备上的唯一因素就是应用的deployment target,而跟其依赖的lib库的deployment target 无关)。在这种情况下,很可能导致我们忽略一些问题,我举个例子:

应用a, 设置deployment target 4.3, 依赖库b,b的deploymenttarget 7.0;我们把a打到一部ios7的设备上运行不会有任何问题;在ios5的设备上运行则会崩溃;我们连接真机调试的时候很可能看到以下的日志:lazy symbol binding failed: Symbol not found:_objc_setProperty_nonatomic.

我们可能会觉得奇怪,这个方法不是我调用的呀?没错,你没有调用这个方法,是系统自己调用了这个方法,而且这个方法是6.0才开始有的,系统更改了属性的底层实现,而在你的设备的系统上不支持该方法,所以就会报这个错误。

结论:我们所依赖的lib库的deployment target不应该高于应用的deployment target,否则很可能报错,而且这个错误不一定是你直接调用的方法,很可能是系统底层代码。

操作建议:在没有技术要求的情况下(如lib库依赖于某个版本的新功能),不要采用默认的deployment target,而是尽可能的把lib库的deployment target设置低一些,这样能够最大程度的保证兼容低版本的设备,也避免上述的奇怪问题的产生。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,464评论 19 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,633评论 25 709
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 47,075评论 6 342
  • 因为要结局swift3.0中引用snapKit的问题,看到一篇介绍Xcode8,swift3变化的文章,觉得很详细...
    uniapp阅读 10,057评论 0 12
  • 我们常常被各种各样的事物所吸引,好像有些事情看上去是我们自己做的决定,其实有很多的情况是我们中了别人的套路,别人利...
    善行无痕阅读 1,449评论 0 0