标签:
在iOS开发中,我们常会用CocoaPods来进行依赖库的管理。CoaoaPods 是一套整体解决方案,我们在 Podfile
中指定好我们需要的第三方库,然后 CocoaPods 就会进行下载,集成,然后修改或者创建我们项目的 workspace
文件。
相比之下,Carthage
就要轻量很多,它也需要一个叫做 Cartfile
的描述文件,但 Carthage
不会对我们的项目结构进行任何修改,更不多创建 workspace
。它只是根据我们描述文件中配置的第三方库,将它们下载到本地,然后使用 xcodebuild
构建成 framework
文件。然后由我们自己将这些库集成到项目中。Carthage
使用的是一种非侵入性的哲学。作为开发者,必须在 Carthage
将第三方库构建完成后,手动的关联到项目中。
另外 Carthage
除了非侵入性,它还是去中心化的,它的包管理不像 CocoaPods
那样,有一个中心服务器(cocoapods.org),来管理各个包的元信息,而是依赖于每个第三方库自己的源地址,比如 Github
。这样也是有利有弊,好处就是我们对包管理不再依赖中心服务器,不会受中心服务器信息量和稳定性的限制(尤其是在我们这里的网络访问状况问题),弊端嘛,就是我们想查找第三方库的时候,也没有一个中心服务器来帮助我们进行索引,而是必须从网络上自行查找。
$ brew update
$ brew install carthage
安装完成后,在终端执行如下指令,可以查看当前carthage的版本:
$ carthage version
$ cd /Users/GofLee/Desktop/Source/SwiftDemo/SwiftDemo/ThirdLibrary
$ touch Cartfile
此时项目文件夹里会创建一个名为Cartfile的文件。
$ open -a Xcode Cartfile
在打开的文件中输入你所要导入的第三方库,示例所示:
github "Alamofire/Alamofire"
github "SwiftyJSON/SwiftyJSON"
当然也可以指定版本号,没有指明版本号的时候,则会自动使用最新的版本。指定版本号示例:
github "Alamofire/Alamofire" ~> 3.4.0
$ carthage update --platform iOS
carthage会为你下载和编译所需要的第三方库,当命令执行完毕,在你的项目文件夹中会创建一个名为Carthage的文件夹。在 ~/Carthage/Build/iOS里会出现framework和dSYM文件,如下所示:
【说明】:
/usr/local/bin/carthage copy-frameworks
最后将 Alamofire 和 SwiftyJSON 的路径添加到 Input Files 中,如下图所示:
添加这个 Run Script 的作用是为了让运行时能够找到这个动态库。这点 Carthage 官方文档中没有太明确的说明。我实际的实验过,如果不添加这个 copy-frameworks
脚本,那么项目在运行的时候会因为找不到这个动态库而在启动的时候崩溃。
生成和配置好第三方库之后,我们可以很简单的来使用,直接在要使用的文件中导入,示例如下:
import Alamofire
import SwiftyJSON
标签:
原文地址:http://www.cnblogs.com/LeeGof/p/5726701.html