cocoapods官网:https://guides.cocoapods.org

一、什么是CocoaPods

每种语言发展到一个阶段,就会出现相应的依赖管理工具,例如 Java 语言的 Maven,nodejs 的 npm。随着 iOS 开发者的增多,业界也出现了为 iOS 程序提供依赖管理的工具,它的名字叫做:CocoaPods。

CocoaPods项目的源码 在 Github 上管理。该项目开始于 2011 年 8 月 12 日,经过多年发展,现在已经成为 iOS 开发事实上的依赖管理标准工具。开发 iOS 项目不可避免地要使用第三方开源库,CocoaPods 的出现使得我们可以节省设置和更新第三方开源库的时间。

二、为什么要使用CocoaPods

在使用CocoaPods之前,开发项目需要用到第三方开源库的时候,我们需要

1.把开源库的源代码复制到项目中

2.添加一些依赖框架和动态库

3.设置-ObjC,-fno-objc-arc等参数

4.管理他们的更新

在使用CocoaPods后,我们只需要把用到的开源库放到一个名为Podfile的文件中,然后执行pod install就可以了,Cocoapods就会自动将这些第三方开源库的源码下载下来,并且为我们的工程设置好响应的系统依赖和编译参数。

三、CocoaPods的原理

CocoaPods的原理是将所有的依赖库都放到另一个名为Pods的项目中,然后让主项目依赖Pods项目,这样,源码管理工作都从主项目移到了Pods项目中。Pods项目最终会编译成一个名为libPods.a的文件,主项目只需要依赖这个.a文件即可。

四、CocoaPods的安装

CocoaPods可以方便地通过Mac自带的RubyGems安装。

打开Terminal(Mac电脑自带的终端),然后按照以下提示操作即可:

1.设置ruby的软件源

这是因为ruby的软件源rubygems.org因为使用亚马逊的云服务,被我天朝屏蔽了,需要更新一下ruby的源,过程如下:

gem sources -l #(查看当前ruby的源)

gem sources --remove https://rubygems.org/ #(移除当前ruby的源)

gem sources -a https://ruby.taobao.org/ #(设置当前ruby的源为我天朝的)

gem sources -l #(再次查看当前ruby的源)

如果Terminal输出:

*** CURRENT SOURCES ***

https://ruby.taobao.org/

就证明ruby的软件源已经设置OK了。

2.设置gem为最新版本

如果gem太老,可以尝试用如下命令升级gem:

在Terminal输入以下命令:

sudo gem update --system

升级成功后会提示: Latest version currently installed. Aborting.

3.执行安装CocoaPods命令

注意:OS X 10.11 升级,虽然官方声称只是一个小的升级,但对于开发者而言,cocoapods需要重新安装,但按照以前的安装方式,在Terminal输入以下命令:

sudo gem install  cocoapods

如果报以下错误:

ERROR:  While executing gem ... (Errno::EPERM)

Operation not permitted - /usr/bin/xcodeproj

解决方案1:

执行下面的命令并重启

sudo nvram boot-args="rootless=0"

sudo reboot

重启之后, 执行这个命令检查

sudo gem install cocoapods -V

如果依旧有错误,使用第二个方案

解决方案2:

sudo gem install -n /usr/local/bin cocoapods

pod setup

还有一点需要注意,pod setup在执行时,会输出Setting up CocoaPods master repo,但是会等待比较久的时间。这步其实是 Cocoapods 在将它的信息下载到 ~/.cocoapods目录下,如果你等太久,可以试着 cd 到那个目录,用du -sh *来查看下载进度。

安装成功后,你会看到:Setup completed

五、Cocoapods的使用

随便以一种方式新建一个名为Podfile的文件放到你的工程根目录下(不能写成别的名字,也可以自己在工程根目录里面直接新建)

Podfile文件内容的格式应该如下:

platform :ios, '8.0' #(注明你的开发平台以及版本,'8.0'忽略不写即为最新版本)

pod 'AFNetworking', '~> 2.5.3' #('~> 2.5.3'为版本号,忽略不写即为最新版本)

pod 'SDWebImage', '~> 3.7.2'

然后在Terminal进入工程所在的根目录(工程根目录)中执行 :

pod install

这样,AFNetworking和SDWebImage就已经下载完成并且设置好了编译参数和依赖,以后使用的时候切记如下两点:

1.从此以后需要使用Cocoapods生成的 .xcworkspace文件来打开工程,而不是使用以前的.xcodeproj文件

2.每次更改了Podfile文件,都需要重新执行一次pod update命令

查找第三方库:

你如果不知道 cocoaPods 管理的库中,是否有你想要的库,那么你可以通过 pod search 命令进行查找,以下是我用 pod search json 查找到的所有可用的库:

可以在Terminal中输入:

pod search AFNetworking

回车之后就可以看到和你搜索的关键字相关的一些库类,如图:

关于 Podfile.lock

当你执行pod install之后,除了 Podfile 外,CocoaPods 还会生成一个名为Podfile.lock的文件,Podfile.lock 应该加入到版本控制里面,不应该把这个文件加入到.gitignore中。因为Podfile.lock会锁定当前各依赖库的版本,之后如果多次执行pod install 不会更改版本,要pod update才会改Podfile.lock了。这样多人协作的时候,可以防止第三方库升级时造成大家各自的第三方库版本不一致

附:如何使用CocoaPods的镜像索引:

所有项目的Podspec文件都托管在https://github.com/CocoaPods/Specs,

第一次执行pod setup时,CocoaPods会将这些podspec索引文件更新到本地的~/.cocoapods目录下,

这个索引文件比较大,所以第一次更新时非常慢.

友好人士在国内的服务器建立了Cocoapods索引库的镜像,

所以执行索引跟新操作时候会快很多.具体操作方法如下:

pod repo remove master

pod repo add master https://gitcafe.com/akuandev/Specs.git

pod repo update

这是使用gitcafe上的镜像,将以上代码中的 https://gitcafe.com/akuandev/Specs.git

替换成 http://git.oschina.net/akuandev/Specs.git 即可使用oschina上的镜像。

推荐阅读:

CocoaPods安装和使用教程

用CocoaPods做iOS程序的依赖管理

CocoaPods极简入门指南

CocoaPods的安装使用和常见问题

2016-10-8号更新

CocoaPods的安装以及遇到的坑

终端安装cocoaPods的方法

最新 macOS Sierra 10.12.3 安装CocoaPods及使用详解相关推荐

  1. 10.12.1 安装cocoapods及使用详解

    一.什么是CocoaPods 每种语言发展到一个阶段,就会出现相应的依赖管理工具,例如 Java 语言的 Maven,nodejs 的 npm.随着 iOS 开发者的增多,业界也出现了为 iOS 程序 ...

  2. macOS Sierra 10.12虚拟机安装

    废话不多说,直接上步骤! 1.安装虚拟机软件 VMware虚拟机软件下载: 链接:https://pan.baidu.com/s/1Ql_ZHtvtCNP2s_UeetapPg 提取码:cs42 下载 ...

  3. 2014年12月2日更新完英雄联盟一直显示无法连接服务器,【致想玩韩服LOL的Mac用户】macOS Sierra[10.12.4可用]下安装英雄联盟新客户端并连接到韩服服务器...

    本帖子致那些想玩韩服LOL的Mac用户 首先,之前我写过一篇帖子是针对Mac用户用旧客户端玩韩服的,不过Riot Games于2017年4月24日废弃旧客户端,在这段时间到2017年5月6日内,均可以 ...

  4. 华硕 X99 E WS 安装 macOS Sierra 10.12.4

    硬件情况: E5 1620 V4 X99 E WS 8GB DDR4 2400 x 4 AMD 7950 3GB 说明: 这里用了免驱卡AMD 7950, 基本在安装阶段都是全分辨率的, 建议所有黑果 ...

  5. 黑苹果macOS Sierra 10.12 安装教程(venue11 pro测试)

    黑苹果macOS Sierra 10.12 安装教程(venue11 pro测试) 2017-03-12 03:46:24 by SemiconductorKING PS:刚刚装好黑苹果,来记录一篇折 ...

  6. macOS Sierra 10.12 汉化软件无法安装

    Mac升级到macOS Sierra 10.12后,发现SVN管理软件Conerstone 2.7破解版已经无法使用,需要更新版本. 安装Cornerstone_3.0.1破解版后,发现提示" ...

  7. PC安装黑苹果 (macOS Sierra 10.12.6)上篇

    1.准备镜像 这里提供的是 macOS Sierra 10.12.6.本镜像采取官方原版macOS Sierra 10.12.6 的app文件封装制作,不用macOS本身的引导,黑苹果大牛为其增加了自 ...

  8. surfacepro4黑苹果触屏_GitHub - MLZC/Surface-Pro-4-Sierra: 微软 Surface Pro 4 macOS Sierra 10.12 黑苹果...

    Surface-Pro-4-Sierra 微软 Surface Pro 4-macOS Sierra 10.12 黑苹果安装教程 机器配置 主板                微软 Surface P ...

  9. mac安装完mysql后关机特别慢_升级macOS Sierra 10.12 关机慢

    作为一个喜欢吃螃蟹的程序猿: 在 macOS Sierra 发布的当天就果断更新了: 当然这次更新对于我等没有 iWatch 的屌丝来说: 在电脑上调戏一番 siri 后:也就没有什么特别好玩的了: ...

最新文章

  1. 安装配置Statspack
  2. 数据结构实验之查找四:二分查找(递归实现和while循环实现)
  3. ldap导入mysql_openLDAP 部署(亲测可用)
  4. JavaScript设计模式(二)之单例模式
  5. spring mvc学习(60):ssm项目整合
  6. init,service和systemctl的区别
  7. 非经营性网站备案流程
  8. 利用第三方工具上传文件
  9. 单表的更新UPDATE和删除记录DELETE(二十六)
  10. 浅谈栈和队列的有关面试题
  11. android groovy方法,Android Gradle从入门到精通(三)Groovy快速入门指南
  12. JAVA 基础语法(四)——循环结构(while,do...while,for,break,continue)
  13. linux安装yum报错Unable to locate package yum解决方案
  14. apple苹果IOS内购申请教程协议、税务和银行业务配置
  15. [lua]紫猫lua教程-命令宝典-L1-01-02. 变量
  16. 微信抖音工具箱头像制作壁纸小程序带改图制图流量主功能搭建动态社群人脉助手
  17. 什么是阿里云aca认证,阿里云aca认证有用吗
  18. 产品化机器学习的一些思考
  19. 基于高通量测序开发甘蓝型油菜全基因组SSR标记
  20. 人生观,世界观,价值观树立的方式

热门文章

  1. Java字节码instrument研究
  2. 吴恩达老师深度学习视频课笔记:序列模型和注意力机制
  3. Sobel算子及cvSobel
  4. 【SVN】linux下svn命令参数详解(二)
  5. 【FFmpeg】解码时refcounted_frames标志的使用
  6. 【linux】ARM开发板上设置RTC时间,断电重启后,设置失效的原因分析
  7. label之间展示间距_cob小间距led显示屏分类
  8. forall分批提交oracle,使用BULK COLLECT+FORALL加速批量提交
  9. html li 右跟下有倒影,HTML5 canvas实现的下雨夜湖面星空倒影动画特效
  10. oracle 条件反转,Oracle反转倒置函数