今天在引入第三方framework时,我按照以前的方法,把framework加入到了下图的地方:

默认是required的,之后程序就crash了,报错dyld: Library not loaded,之后我把required 改成了optional,这次不crash了,但是运行时出错,库中的对象无法实例化,全部是空。

我是根据http://stackoverflow.com/questions/24333981/ios-app-with-framework-crashed-on-device-dyld-library-not-loaded-xcode-6-beta解决的,就是利用Embeded Binaries选项。

先看看optional 和 required 有什么区别,如下是官方的说法:

Libraries and frameworks are designated as Required by default, but you can change this designation to Optional. Required libraries must be present on the host computer for the product to load. Optional libraries do not have to be present for the product to load. A Required framework will always be loaded into memory, but an Optional framework will be loaded only if needed. The initial load of the application will be faster if a large library that is never needed is designated as Optional.

在看看framework的官方说明:

A framework is a hierarchical directory that encapsulates shared resources, such as a dynamic shared library, nib files, image files, localized strings, header files, and reference documentation in a single package. Multiple applications can use all of these resources simultaneously. The system loads them into memory as needed and shares the one copy of the resource among all applications whenever possible.

注意,根据上面的介绍,看起来framework中只能包含 dynamic shared library 2进制文件,其实不是,framework 中也可以包含静态库2进制文件!通过下面这个参数来指定:

这里如果指定为 Static Library(framework中包含的2进制文件就是个静态库),那么当这个framework就可以只加入Linked Frameworks and Libraries 选项卡中,系统会自动识别它的类型,并链接入目标文件。而如果指定为Dynamic Library(framework 中包含的2进制文件就是个动态库) ,那么,加入到 Linked Frameworks and Libraries 选项卡中是不够的,而是需要加入到Embeded Binaries选项卡中,加入后系统会自动为你在Linked Frameworks and Libraries选项卡里加入相同framework,打开对应的ipa,会看到 framework在单独的一个文件夹中。我这里的理解是,Linked Frameworks and Libraries表示连接,动态连接也算连接,所以Embeded Binaries选项卡中中的项目也会出现在Linked Frameworks and Libraries选项卡中。

另外,如果framework中包含的2进制文件是个静态库,而我们把这个framework当成一个包含动态库的framework,添加到了Embeded Binaries选项卡中,那么程序无法通过编译,会报错的。

如何看一个framework中的2进制文件是一个静态库还是一个动态库呢?使用file 命令。

见下面的截图,一个动态库,一个静态库:

看到这里可以明白了,framework就是把以前的.a 和 .so 文件又包装了一层目录,加入了些其他必要的文件,比如以前用.a时需要单独引入的一系列.h文件,这样看起来更规范一些!

这里还有一篇好的博文 http://www.cnblogs.com/huizhang212/p/lipolib.html,说的是如何从.a除去不要的.o文件。

就是说,如果引入了第三方的动态库,这个包含动态库的framework就需要添加到 ipa包中,加载的时机看参数,如果是required,那么程序载入时就加载,如果是optional,那么是使用到时,才加载。如果引入了静态库,这个.a的链接也看参数?不都是需要把部分2进制代码链接入目标文件吗?有什么区别吗?不太明白。我觉得当使用静态库时,这个required 和 optional就没什么用了。

关于创建自定义framework,需要仔细研究一下这篇文章http://www.cocoachina.com/ios/20141126/10322.html


又遇到了一个问题,用embeded 方式加入 lumberjack framework 后,运行时总出如下警告:

objc[]: Class DDTTYLogger is implemented in both /private/var/containers/Bundle/Application/621285FC-47C0--A664-2764018435AD/Gamification.app/Frameworks/CocoaLumberjack.framework/CocoaLumberjack and /var/containers/Bundle/Application/621285FC-47C0--A664-2764018435AD/Gamification.app/Gamification. One of the two will be used. Which one is undefined.

我搜索了工程源码,没有发现其他定义这个类的地方,之后,为了测试,我删掉了 lumberjack framework ,直接加入了lumberjack.a 进行编译,这次直接报错了!这次错误就写的很明白了,原来是工程引入的另一个.a中已经包括了lumberjack的源码,我又没有这个.a的源码,所以在工程中就搜索不到另一个定义。

这也是解决这种类似问题的小技巧吧。

iOS 引入framework的常见问题和原理的更多相关文章

  1. iOS程序启动的过程及原理

    iOS程序启动的过程及原理 文字部分 先执行main函数,main内部会调用UIApplicationMain函数 UIApplicationMain函数里面做了什么事情??? 1> 创建UIA ...

  2. IOS热更新-JSPatch实现原理+Patch现场恢复

    关于HotfixPatch 在IOS开发领域,由于Apple严格的审核标准和低效率,IOS应用的发版速度极慢,稍微大型的app发版基本上都在一个月以上,所以代码热更新(HotfixPatch)对于IO ...

  3. iOS开发 .framework的Optional(弱引用)和Required(强引用)区别, 有错误 Library not found………………

    http://www.cnblogs.com/wanyakun/p/3494323.html 强引用(Required)的framework是一定会被加载到内存的,但是弱引用(Optional)的fr ...

  4. iOS 打包.framework(包括第三方、图片、xib、plist文件)详细步骤及需要注意的地方

    https://www.cnblogs.com/yk123/p/9340268.html // 加载自定义名称为Resources.bundle中对应images文件夹中的图片// 思路:从mainb ...

  5. iOS中,Framework和.a的打包及使用

    最近在做一个小项目,需要给客户一个demo测试,有一部分核心代码暂时不想让客户知道,就想到了打包成framework或.a库.库有两种: 静态库:.a和.framework 动态库:.tbd和.fra ...

  6. iOS引入JavaScriptCore引擎框架(二)

    为何放弃第一种方案 UIWebView的JSContext获取     上篇中,我们通过简单的kvc获取UIWebVIew的JSContext,但是实际上,apple并未给开发者提供访问UIWebVi ...

  7. iOS引入JavaScriptCore引擎框架(一)

    JavaScriptCore引擎     我们都知道WebKit是个渲染引擎,简单来说负责页面的布局,绘制以及层的合成,但是WebKit工程中不仅仅有关于渲染相关的逻辑,也集成了默认的javascri ...

  8. iOS在线更新framework,使用NSBundle动态读取

    官方文档:https://developer.apple.com/library/mac/documentation/Cocoa/Conceptual/LoadingCode/Tasks/Loadin ...

  9. iOS Photos.framework框架

    链接: iOS8.0 使用Photos.framework对相册的常用操作 iOS AssetsLibrary和Photos的使用总结: 权限及相册的获取 iOS 开发之照片框架详解 iOS Asse ...

随机推荐

  1. 关于vs2012、tfs2012、windows server 2008r2一些记录

    windows server 2008r2安装在虚拟机中,装有tfs2012.sql server 2012. 物理机装有vs2012 1.用vs2012连接tfs时候,会让输入一个有效用户.输入的是 ...

  2. MyBatis参数传入集合之foreach用法

    传入集合list // 账户类型包括门店和分公司 List<Object> scopeList = new ArrayList<Object>(); scopeList.add ...

  3. jQuery给动态添加的元素绑定事件的方法

    我们在开发过程会遇到无法给动态元素添加绑定事件,解决方案如下: 例如 <div id="testdiv">   <ul></ul> </d ...

  4. SVN随记

    SVN中提交代码时报如下错误 commit -m "sync" E:/resource/rad_workspace/IMSCrawl/src/configuration.prope ...

  5. deepin 15.3 安装配置nginx

    1.安装nginx sudo apt-get install nginx 2.配置nginx sudo gedit /etc/nginx/sites-enabled/default 找到:index ...

  6. 【bzoj1085】 SCOI2005—骑士精神

    http://www.lydsy.com/JudgeOnline/problem.php?id=1085 (题目链接) 题意 给出一个初始局面,问能否在15步内走到最终局面,并输出最少步数. Solu ...

  7. mogodb3.2源码安装

    mogodb3.2源码安装 下载链接: http://www.mongodb.org/downloads 1.环境准备: 1.mkdir -p /data/tgz #创建存放软件的目录 2.mkdir ...

  8. SQLAlchemy文档翻译

    想记录一下SQLAlchemy的入门学习,然后突发奇想觉得:为什么不直接翻译一下文档呢?于是顺手查了查怎么使用Gitbook,2333 于是就在Github开了项目,然后导入了Gitbook,开始写. ...

  9. JointBoost+CRF+GraphCut做手绘草图的分割

    研究生做的稍微有点水平的就这两个项目了:一个是利用SVM做手绘草图的分类,另一个是利用JointBoost+CRF做手绘草图的分割.总结得出的经验是做研究的方法就是将别人大神的代码看懂然后改成适合自己 ...

  10. awk删除文件第一列

    awk删除文件第一列 1.采用awk awk '{$1="";print $0}' file 2.采用sed sed -e 's/[^]* //' file sort -R fil ...