该入门教程的流程是这样的;
什么是Git----------------->为什么选择Git----------------->如何安装Git到MAC OS X------------------>如何使用Git

具体如下;

1, 首先要了解什么是Git。

简而言之,Git是一个分布式的代码版本管理工具。类似的常用工具还有SVN,CVS。

概念了解参见;http://baike.baidu.com/subview/1531489/12032478.htm?fromId=1531489&from=rdtself&fr=wordsearch

2,为什么要使用Git。

Git相比SVN,CVS,最大的特点也是优点在于提供分布式的代码管理。这不是说SVN等不具有该功能,但就目前来看,Git更完善,而且也越来越多地被人们所接受。前途和易用是我一向选择的基准。

在使用中,目前体验到最大的相比SVN的好处有;
分支代码只有一份!log在本地!合并代码更加方便!更加安全!目录更加简洁!

简单做下解释;

分支代码只有一份!
使用过svn的童鞋想必都知道,当我们要开发一个新功能或者增加一个新版本或者修改一个复杂bug的时候,通常需要copy整份代码到本地一个目录,然后添加到svn服务器上进行代码管理。
而Git不同,Git可以创建许多branches,每个branch都是独立的,当我们需要修改代码的时候,commit也只是对本地仓库的修改。如果使用SourceTree,我们会发现在工具栏的Git Flow功能,已经很好的为此做了准备。

log在本地!
svn的log都是存储在服务器上的,当我们要查阅修改记录的时候,必须要能够连接上远程服务器,并且具有权限。而Git不同,Git对于本地仓库的修改记录都是在本地上的,方便查阅。

合并代码更加方便!
因为Git支持本地无限Branches,当我们个体在本地创建多个branches用于不同目的的时候(修改,新增,探索),合并一份代码显然要比svn合并一堆工程copy更加简单。

更加安全!
Git的commit命令不同于SVN,commit只是对本地仓库代码的一次更新。当需要提交到master远程仓库,或者其他远程分支仓库的时候,需要使用push功能。虽然增加了一个过程,却可以防止随意修改导致后期合并出现大问题的风险。

目录更加简洁!
在Git本地仓库根目录,只有一个.git文件,它包含了所有的管理信息。而SVN想必大家都知道,每个子目录下都有噁心的.svn。这个当需要修改文件冲突等问题时,就需要考虑了。肯定是一个文件简单。

3, 如何安装Git到MAC OS X
这里介绍两种方式;
一,使用Git command-line
二,使用GUI工具SourceTree,功能很强大,很方便

在进行安装前,要说一下,Git和SVN一样,都需要创建一个服务器的,他们都可以创建自己的版本管理服务器。对于个人和小团队来说,使用托管服务器可能更合适,
常见的有Github 和 Bitbucket。这里我介绍下Bitbucket,Github因为没有个人免费仓库使用,代码放上去就是开源的,所以这里我选择Bitbucket。另外,现在Bitbucket的个人仓库相关页面已经基本汉化了。注册流程也比较简单。
详见链接;https://bitbucket.org/

这里先介绍下使用Command-line。
1,下载Git installer,地址;http://git-scm.com/downloads
2,下载之后打开,双击.pkg安装
3, 打开终端,使用git --version命令查看安装版本,有就是安装成功了
/*以下4.5命令如果已经使用Bitbucket创建过了,将会自动包含*/
4,创建一个全球用户名
git config --global user.name "FIRST_NAME LAST_NAME"
5,创建一个全球邮箱
git config --global user.email "MY_NAME@example.com"
6, 如果不想每次连接远程仓库都输入密码的话,输入如下命令
git credential-osxkeychain
------>等待
git config --global credential.helper osxkeychain
# Set git to use the osxkeychain credential helper
到此Git就安装完成了。

二,关于SourceTree这里先不做介绍。初始安装和SVN类似。

4, 如何使用Git
这里也介绍两种方式
一,使用command
二,使用SourceTree

先介绍第一种;Command line

使用终端的命令行时,首先我们要有一定的linux命令行知识。实际使用中经常用到的比较少,这里只介绍一些必要的。
参考链接;http://www.renfei.org/blog/mac-os-x-terminal-101.html

linux基础命令;
sudo -s   获取绝对用户权限
cd xxx    进入xxx目录
ls (-a/-A)   显示当前路径下所有文件(隐藏的)
pwd       显示当前绝对路径
mkdir  xxx   创建文件夹xxx
man xxx     查看xxx命令手册

然后介绍下Git基础命令的含义;
clone   克隆远程仓库
init       初始化仓库
remote 连接远程仓库
pull      从远程仓库下拉获取新数据
push    将本地仓库新增或修改文件上传到远程仓库
add     添加文件或者修改文件,commit以及push之前使用
log      当前仓库提交过的日志信息
status  当前仓库版本状态
commit 提交到当前仓库中
branch 分支命令,相关增删查操作
checkout 使用远程仓库最后一个版本完全覆盖当前仓库内容/选择分支branch
diff      对比版本内容
merge   合并版本内容
详细参见链接;https://confluence.atlassian.com/display/BITBUCKET/Bitbucket+Documentation+Home

使用Git,我们当然要有一个远程仓库,这里假设我们已经创建好了Bitbucket账号(创建远程仓库repository使用)。
创建远程仓库的方法这里也介绍两种方式。
一,使用Git 命令创建
二,在Bitbucket上创建

第一种,使用Git 命令行

初始化
git init
--------->
从Bitbucket上复制仓库地址
--------->
添加别名为origin的源到远程仓库地址
git  remote  add  origin  https://myAccountName@bitbucket.org/myAccountName/myRepositoryName.git

第二种,Bitbucket上创建远程仓库
注册之后按照提示创建即可,非常简单。。。不再复述。
详见参考;https://confluence.atlassian.com/display/BITBUCKET/Bitbucket+Documentation+Home中的Bitbucket 101文档

---------以上为初始创建--------------华丽的分割线---------------以下为操作版本库-------------------

有了远程仓库Repostiory,我们该添加代码或者其他文件什么的了

这里还是介绍两种;
一, 使用command-line
二, 使用SourceTree

第一种, 使用command-line
在本地目录链接了远程仓库后(clone命令),使用如下方法操作文件。

git add xxx           添加或要修改的xxx文件
------------------>
git commit -m "adding repo instructions"         提交xxx文件到本地仓库版本中 ;-m “XXXX” ;提交log
------------------>
git push -u origin master                提交xxx和log,到远程仓库origin(刚才创建的远程仓库Repository的别名)的master分支下

第二种, 使用SourceTree
和svn类似,具体流程为;
add----添加文件到索引----->commit------提交到本地仓库------>push--------上传到远程仓库--------->

之后就是对仓库中文件的增加修改删除操作了

Ps:记得如果不是单独另需创建的branch,每次对本地仓库操作的时候都要使用 git pull命令,更新远程仓库到本地中,防止冲突。这点和SVN的update类似

先介绍到这里,其实操作起来基本和SVN的命令行工具还有gui工具类似。
实际使用中主要区别还是分布式的开发模式不同。

欢迎大家来补充~

----------------------------------------------------------------------分割线-------------------------------以下为对Git的Branch进行说明-------------------------------------------------

Branch就是分支,Git相比SVN,最大的优点是完善的分布式管理。每一个本地的Repository,也就是仓库,都相当于一个本地版本服务器,在此基础上我们可以进行许多Branches,进行不同
类型的开发。Branch的目录统一性使得它的管理,包括merge非常简单方便。

一, 先介绍下SourceTree下的Branch,
这里提供个比较详细的博客链接,供大家参考,图文并茂,已经解释的比较详细了,不再复述。
参考地址: http://www.takobear.tw/12/post/2014/02/bear-git-flow-sourcetreegit-flow.html

二, 使用command-line创建branch分支

待续。。。。。。

----------------------------------------------------------------------分割线-------------------------------以下为小技巧-----------------------------------------------

1,   Git Stash命令
说到branches,使用Git开发较复杂的项目我想本地肯定会有多个。假如我们有一个临时紧急的重要任务,需要切换到其它branch,那么我们需要commit当前的内容。
但是,假如我修改的内容比较乱,或者其它什么原因不想提交到仓库中呢,这时候我们就可以使用Stash命令了。
$ git stash
这个命令的意思是将当前工作区的内容放到一个临时的区域,这意味着,使用git status,或者add commit命令,是无效的。
但是我们很好的保护了现场。接下来就可以checkout到其它branch工作了。

回来之后,要回复一下现场。这里要简单说明下,stash命令的一个工作机制。
当使用了stash命令后,当前工作区域的内容会被push进一个栈队列里,是的,就和navigationController一样。
假如我们要回复现场。有两种选择;pop, 或者apply

pop顾名思义,当前暂存内容从栈队列里消失了,apply则和objectAtIndex一样,队列里仍然有该暂存内容。

当多个branches被我们stash的时候,会用到如下两个命令;

git stash list: 显示Git暂存栈内的所有备份,可以利用这个列表来决定从那个地方恢复。
git stash clear: 清空Git栈。此时使用gitg等图形化工具会发现,原来stash的哪些节点都消失了。

Ps:记住,多多使用git status 命令,就好比,好记性不如烂笔头。git 帮我们做好的笔记要多多查看,防止出错。

2,  让Git忽略烦人不想追踪的文件
一,可以设置整个Git仓库需要忽略的文件。
$ git config –global core.excludesfile ~/.gitignore_global
$vim ~/.gitignore_global

然后在.gitignore_global文件里面设置我们想要忽略的文件。比如添加如下
# Mac OS X
*.DS_Store

# Xcode
*.pbxuser
*.mode1v3
*.mode2v3
*.perspectivev3
*.xcuserstate
project.xcworkspace/
xcuserdata/

#Git
.gitingore
.gitingore.swp

之后保存就可以了。如果输入git status仍然提示有不期望的被追踪的文件。需要清理下
$ git rm --cache xxx    xxx为想要忽略的文件

好了,再也不会有烦人的文件了

二,可以单独为某个目录设置忽略文件。
到想要忽略文件的目录下,
$ vim .gitignore
添加如上规则的名字
保存之后,退出,就可以了。

关于忽略文件的命名规则,请参考链接:
http://bdxnote.blog.163.com/blog/static/844423520124153051409/

mac os x使用Git简易入门教程相关推荐

  1. Markdown 简易入门教程

    自己整理的 Markdown 简介.编辑器推荐.语法.特征等,是 Markdown 的简易入门教程 目录 概述 简介 官方文档 Markdown编辑器 初级语法 标题 粗体和斜体 段落和换行 分隔线 ...

  2. Git完整入门教程(从0开始)

    前言 本博客是Git的入门教程,刚刚接触Git的朋友们参照本博客流程便可以在自己电脑上实现本地与云端Github的交互,同时本博客中使用到的Git指令也是最基本的. 文章目录 前言 初始化Git仓库 ...

  3. layui个人中心html,Layui的简易入门教程

    layui是一款采用自身模块规范编写的前端UI框架,非常适合界面的快速开发.本篇文章给大家分享一下Layui的简易入门教程,介绍一下layui如何在你的项目中使用. 获得 layui 后,将其完整地部 ...

  4. Gradle 简易入门教程

    作者: Yann 来源:原力注入 Gradle 是一种构建工具,它抛弃了基于XML的构建脚本,取而代之的是采用一种基于 Groovy(现在也支持 Kotlin)的内部领域特定语言. Gradle特点 ...

  5. Mac OS + IntelliJ Idea +Git 开发环境搭建实战

    版权声明:本文为笔记里的蹉跎出品,文章可共享,转载请声明. 本文主要内容: - 1.Mac OS 10.11.6 [OS X EL Captain] - 2.Mac OS 安装Java 设置环境变量 ...

  6. FL studio 20简易入门教程 -- 第四篇 -- 钢琴卷帘窗口与单轨乐器编辑界面

    钢琴卷帘窗口与单轨乐器编辑界面 本文经验主要来自于B站爱编曲网官方正版快速入门教程,链接如下: 爱编曲网官方正版快速入门教程 文章目录 钢琴卷帘窗口与单轨乐器编辑界面 前言 单轨乐器编辑界面 上方菜单 ...

  7. 【转】windows环境下安装win8.1+Mac OS X 10.10双系统教程

    先要感谢远景论坛里的各位大神们的帖子  没有他们的分享我也不能顺利的装上Mac OS X 10.10! 写这篇随笔主要是为了防止自己遗忘,同时给大家分享下我的经验. 本教程适用于BIOS+MBR分区的 ...

  8. Mac OS X 懒人版安装教程(之前的图全部挂了,所以重发了)

    请版主把我之前发的那个帖子删了!因为所有的图全部挂了,所以麻烦版主了-- 安装中出现五国的话就请进入这里看看是那里的错误http://bbs.pcbeta.com/viewthread-863656- ...

  9. Mac OS X平台下QuickLook开发教程

    一.引言 Quick Look技术是Apple在Mac OS X 10.5中引入的一种用于快速查看文件内容的技术.用户只需要选中文件单击空格键即可快速查看文件内容,可以在不打开文件的情况下快速浏览内容 ...

最新文章

  1. Google Chrome input 设置 line-height 后光标变得和input一样高
  2. JUnit规则–引发异常时执行附加验证
  3. oracle追踪触发器语句,Oracle中怎样通过触发器来追踪用户的活动?
  4. 43 WM配置-作业-库存盘点-定义每种存储类型的类型
  5. 闭包函数和装饰器(待补充)
  6. MCU串行通讯和并行通讯的区别以及UART的理解
  7. 虚拟机 系统镜像 下载地址
  8. spring框架对jdk版本要求
  9. 演绎、归纳与前言结构——Leo鉴书83
  10. 走进小作坊(九)----省时省力的二八法则
  11. erlang 之简单的Diction实现
  12. 第五章:量化研究专题(第四篇:统计套利:利用相关系数进行配对交易 )
  13. 2.5 zio入门——ZIO类型别名
  14. 容器技术-Docker 网络03-用户自定义网络-网络命令的使用
  15. SQL Inject
  16. PVLAN 技术介绍
  17. JGit操作之2.0版
  18. unique中译_UNIQUE是什么意思_ UNIQUE的翻译_音标_读音_用法_例句_爱词霸在线词典...
  19. 什么是HBA(Host Bus Adapter,HBA)
  20. 1.windows 应用程序开发(MessageBox 和 DialogBox 和 WM_COMMAND)

热门文章

  1. 时间卷积网络(TCN)在唇语识别中的应用
  2. 原神私服 grasscutter搭建及食用教程 v3.3
  3. OpenNI2的安装教程
  4. GPRS手机+笔记本电脑无线上网
  5. CSS 重要属性与定位
  6. 第六周作业 百词斩对比可可英语
  7. 人手一份!八大危险作业操作规程、作业票证(模板)、安全培训齐了~
  8. [项目管理]敏捷宣言
  9. 社会保障计算机考试证书查询,便利查|打开电子社保卡可查询职业资格证书啦!...
  10. 2021年中国强脉冲光器械行业发展趋势分析:市场规模不断增长,进口品牌占比大[图]