一、CocoaPods
为什么需要CocoaPods
在进行iOS开发的时候,总免不了使用第三方的开源库,比如SBJson、AFNetworking、Reachability等等。使用这些库的时候通常需要:
下载开源库的源代码并引入工程
向工程中添加开源库使用到的framework
解决开源库和开源库以及开源库和工程之间的依赖关系、检查重复添加的framework等问题
如果开源库有更新的时候,还需要将工程中使用的开源库删除,重新执行前面的三个步骤,顿时头都大了。。。
自从有了CocoaPods以后,这些繁杂的工作就不再需要我们亲力亲为了,只需要我们做好少量的配置工作,CocoaPods会为我们做好一切!
什么是CocoaPods
CocoaPods是一个用来帮助我们管理第三方依赖库的工具。它可以解决库与库之间的依赖关系,下载库的源代码,同时通过创建一个Xcode的workspace来将这些第三方库和我们的工程连接起来,供我们开发使用。
使用CocoaPods的目的是让我们能自动化的、集中的、直观的管理第三方开源库。
安装Ruby环境
Ruby是一门开发语言,gem为Ruby第三方库管理工具,CocoaPods是用Ruby写的一个第三方工具。
1.安装Ruby环境需要安装Xcode及Command Line Tools。
2.安装Command Line Tools:
xcode-select --install
-
3.安装RVM,Ruby的多版本管理工具。
$ curl -L https://get.rvm.io | bash -s stable $ source ~/.rvm/scripts/rvm $ rvm install 2.3.0 $ rvm use 2.3.0 $ /bin/bash --login
-
4.修改 gem 镜像
$ gem sources --add https://gems.ruby-china.org/ --remove https://rubygems.org/ $ gem sources -l https://gems.ruby-china.org # 确保只有 gems.ruby-china.org
如果出现多个需要将其余的源删除。
注:
1.淘宝的 ruby 源已经不维护了,所以这里直接换成了 Ruby China,详情请见:
https://gems.ruby-china.org/
2.gem是管理Ruby库和程序的标准包,如果它的版本过低也可能导致安装失败,解决方案自然是升级gem,执行下述命令即可:
$ sudo gem update
安装 CocoaPods
$ gem install cocoapods
执行完成后,需要初始化CocoaPods的环境
$ pod setup
注:初始化过程可能会非常漫长,需要耐心等待即可。
使用CocoaPods
创建Xcode工程并切换到该工程路径
使用命令
pod init
在当前文件夹下生成一个Podfile文件-
编辑该文件,在该文件中输入如下信息:
$ vim Podfile # Uncomment this line to define a global platform for your project platform :ios, '8.0' target 'CocoaPodsDemo' do # Uncomment this line if you're using Swift or would like to use dynamic frameworks # use_frameworks! # Pods for CocoaPodsDemo pod "AFNetworking", "~> 2.5.4" pod 'SDWebImage' pod 'KVNProgress' target 'CocoaPodsDemoTests' do inherit! :search_paths # Pods for testing end target 'CocoaPodsDemoUITests' do inherit! :search_paths # Pods for testing end end
该文件中的命令格式为:
pod '第三库名称', '版本号'
第三库名称,名称一定要正确,不然有可能安装失败。
版本号标识区别
>= 1.0 至少版本为1.0
~> 1.0 兼容1.0版本的最新版
== 1.0或1.0 都表示指定版本
-
安装工程依赖的第三方库
$ pod install Updating local specs repositories Analyzing dependencies Downloading dependencies Installing AFNetworking (2.5.4) Installing KVNProgress (2.2.2) Installing SDWebImage (3.7.3) Generating Pods project Integrating client project [!] Please close any current Xcode sessions and use `CocoaPodsDemo.xcworkspace` for this project from now on. Sending stats Pod installation complete! There are 3 dependencies from the Podfile and 3 total pods installed.
若出现
pods installed
字样表示安装成功。 关闭Xcode工程,打开.xcworkspace文件。
在工程中导入第三库文件,只需要
#import <AFNetworking.h>
类似的即可,开启CocoaPods之旅。
更多用法参考本文提供的参考链接。
参考链接
- http://code4app.com/article/cocoapods-install-usage
- http://blog.csdn.net/wzzvictory/article/details/18737437
- http://blog.csdn.net/wzzvictory/article/details/19178709
二、 Carthage
Carthage简介
Carthage的目标是用最简单的方式来管理Cocoa第三方框架。
Carthage编译你的依赖,并提供框架的二进制文件,但你仍然保留对项目的结构和设置的完整控制。Carthage不会自动的修改你的项目文件或编译设置。
Carthage只正式支持动态框架,动态框架能够在任何版本的OS X上使用,但只能在iOS 8及以上版本使用。
安装Homebrew
OS X 不可或缺的套件管理器,用于安装命令工具。
终端中执行如下命令:
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
安装Carthage
终端执行命令安装Carthage
brew update
brew install carthage
使用Carthage
创建Xcode工程并切换到该工程路径
-
创建一个
Cartfile
,将你想要使用的框架列在里面github "AFNetworking/AFNetworking" ~> 3.0 github "rs/SDWebImage"
运行
carthage update
,将获取依赖文件到一个Carthage.checkout
文件夹,然后编译每个依赖在你的应用程序target的
General
设置标签中的Embedded Binaries
区域,将框架从Carthage.build
文件夹拖拽进去。
参考链接
三、 Carthage与CocoaPods的不同
Carthage只支持iOS 8及以上版本使用。
首先,CocoaPods默认会自动创建并更新你的应用程序和所有依赖的Xcode workspace。Carthage使用xcodebuild来编译框架的二进制文件,但如何集成它们将交由用户自己判断。CocoaPods的方法更易于使用,但Carthage更灵活并且是非侵入性的。
-
CocoaPods的目标在它的README文件描述如下:
…为提高第三方开源库的可见性和参与度,创建一个更中心化的生态系统。
与之对照,Carthage创建的是去中心化的依赖管理器。它没有总项目的列表,这能够减少维护工作并且避免任何中心化带来的问题(如中央服务器宕机)。不过,这样也有一些缺点,就是项目的发现将更困难,用户将依赖于Github的趋势页面或者类似的代码库来寻找项目。
CocoaPods项目同时还必须包含一个podspec文件,里面是项目的一些元数据,以及确定项目的编译方式。Carthage使用xcodebuild来编译依赖,而不是将他们集成进一个workspace,因此无需类似的设定文件。不过依赖需要包含自己的Xcode工程文件来描述如何编译。
最后,我们创建Carthage的原因是想要一种尽可能简单的工具——一个只关心本职工作的依赖管理器,而不是取代部分Xcode的功能,或者需要让框架作者做一些额外的工作。CocoaPods提供的一些特性很棒,但由于附加的复杂性,它们将不会被包含在Carthage当中。