1.为何要使用管理工具管理项目的依赖关系
我们在开发过程中会用到(依赖于)其他第三方库,这些库或框架还有可能依赖于其他库或者框架,手动管理这些库或者框架非常麻烦,首先我们需要下载这些库或者框架,然后还要考虑版本兼容性问题,需要手动导入一些依赖包,还好有CocoaPods和Carthage工具管理项目依赖关系。
2.使用CocoaPods工具管理依赖
CocoaPods是非常好用的第三方依赖管理工具,它于2011年发布,经过这几年的发展,已经非常完善。CocoaPods支持项目中采用Objective-C或swift语言。CocoaPods会将第三方库的源代码编译为静态库.a文件或者动态框架.framework文件的形式,并将它们添加到项目中,建立依赖关系。
使用方法
pod search MBProgressHUD
或者进入CocoaPods 官网https://cocoapods.org/,输入第三方库名称,可以便捷的查看相应库的使用方法。
Carthage工具
CocoaPods是一个非常棒的工具,但我们还有另外一个选择——Carthage,它是一个轻量级的项目依赖管理工具。Carthage主张“去中心化”和“非侵入性”。
CocoaPods搭建了一个中心库,第三方库被收入到该中心库,所以没有收录的第三方库是不能使用CocoaPods管理的,这就是所谓的”中心化“思想。而Carthage没有这样的中心库,第三方库基本上都是从GitHub或者私有git库中下载的,这就是“去中心化”。
另外,CocoaPods下载第三方库后,会将其编译成静态链接库或者动态框架文件,这种做法会修改Xcode项目属性配置依赖关系,这就是所谓的”侵入性“。而Carthage下载成功后,会将第三方库编译为动态框架,由开发人员自己配置依赖关系,Carthage不会修改Xcode项目属性,这就是所谓的”非侵入性“。
Carthage安装
第一种是在https://github.com/Carthage/Carthage/releases 网站下载已经编译好的安装包Carthage.pkg,然后进行安装。
第二种是通过Homebrew工具进行安装。Homebrew是用来管理OS X系统下安装包的工具,使用非常之便利。下面主要介绍第二种。
第一步:打开终端:
brew list
第二步:如果没有安装Homebrew工具,终端会提示brew命令无法执行,然后执行如下指令安装homebrew
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
第三步:执行如下指令,安装Carthage
brew install carthage
第四步:执行如下指令,查询Carthage是否安装成功
brew list //如果出现carthage,说明安装成功
Carthage使用
第一步:终端输入如下指令:
cd /Users/admin/Desktop/exercise/Carthage (cd后面的是你创建工程的路径,直接将工程拖到终端中即可自动生成)
第二步:与cocoapods一样,Carthage同样需要一个类似podfile文件,我们可以命名为Cartfile(这里的名字可以任意命名),然后终端输入如下指令,进入该文件中:
vim Cartfile
第三步:进入Cartfile文件后与cocoapods的使用方式一样,输入i,进入编辑模式,然后执行下面的指令,输入wq:进行保存,然后就退出Cartfile文件了:
github "https://github.com/AFNetworking/AFNetworking.git"
或者 github "AFNetworking / AFNetworking" "master"
(ps:二者任选其一即可,如果采用第二种方式,指定的依赖库一般为github上的"用户名/项目名",如果不是很确定名称,可以输入第三方的名称,到github上确认即可,使用第一种方式其实是项目的下载链接,同样,如果不是很确定,可以到github上复制粘贴下来即可)
和Podfile类似,在Carthage文件中也可以指定依赖库的版本
~>3.0 表示大于等于3.0版本,小于下一个主版本,即4.0版本
>=3.0 表示大于等于3.0版本
==3.0 表示等于3.0版本
第四步:终端输入如下指令,下载文件
carthage update --platform iOS
第五步:执行完上面的操作后,打开项目,会发现项目中多了一个Carthage文件夹,在它下面又有俩个子文件夹Build和Checkouts,
Build目录中存放编译好的framework文件,
Checkouts目录是下载的第三方库源代码
点击Add Other,找到需要添加的库依次导入即可,这里需要导入的库是AFNetworking.framework。
第六步:选择Build phases ,点击左上角的加号,如下图:
选择 New Run Script phase ,在Run Script部分的脚本区域输入:
/usr/local/bin/carthage copy-frameworks
然后将路径添加到 Input Files中:
$(SRCROOT)/Carthage/Build/iOS/AFNetworking.framework
最终效果图如下:编译工程即可。