GIT Study Notes

〇、思维导图


一、简介


  • 是一个开源分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目;
  • 是Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件;
  • 与常用的版本控制工具CVS, Subversion等不同,它采用了分布式版本库的方式,不必服务器端软件支持;
  • 不仅是版本控制系统,也是内容管理系统(CMS),工作管理系统等。


  • 注意
    • “分布式”的特性指的是版本库的分布式,也就是说GIT可以在本地创建版本库(不像SVN不能提交版本到本地库)。



二、GIT和SVN区别

 

  • 核心区别 GIT是分布式的,SVN不是;
  • 存储方式 GIT把内容按元数据方式存储,而SVN是按文件;
  • 文件存储方式 所有的资源控制系统都是把文件的元信息隐藏在一个类似.svn,.cvs等的文件夹里。
  • 分支GIT分支和SVN的分支不同,分支在SVN中一点不特别,就是版本库中的另外的一个目录;
  • 全局版本号 GIT没有一个全局的版本号,而SVN有:目前为止这是跟SVN相比GIT缺少的最大的一个特征;
  • 内容完整性 GIT的内容完整性要优于SVN:GIT的内容存储使用的是SHA-1哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。



三、安装和配置

  • 此部分可以参考其他资料



四、工作流程

 

  1. 从远程版本库上克隆完整的GIT仓库(包括代码和版本信息)到本地;
  2. 在本地根据不同的开发目的,创建分支,修改代码;
  3. 在本地自己创建的分支上提交代码;
  4. 在本地合并分支;
  5. 把远程版本库上最新版的代码fetch下来,然后跟自己的主分支合并;
  6. 如果没有主开发者,可以直接把代码push到远程版本库;
  7. 生成补丁(patch),把补丁发送给主开发者;
  8. 看主开发者的反馈,如果主开发者发现两个一般开发者之间有冲突(他们之间可以合作解决的冲突),就会要求他们先解决冲突,然后再由其中一个人提交。如果主开发者可以自己解决,或者没有冲突,就通过;
  9. 一般开发者之间解决冲突的方法,开发者之间可以使用pull 命令解决冲突,解决完冲突之后再向主开发者提交补丁。
  10. 图例



五、工作区、暂存区和版本库

 

1 工作区

GIT仓库同级目录。


2 暂存区

一般存放在GIT目录下的index文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。


3 工作区

工作区有一个隐藏目录.git。


  • 注意:
    • git add是把文件添加到暂存区(索引),需要进一步commit更新到本地版本库中;
    • git reset HEAD、git rm --cached<file>、git checkout、git checkout HEAD命令详细;
    • 解决冲突之后的文件直接commit的话,不会默认加入到暂存区(没有冲突的时候直接commit会默认把文件加入到暂存区),需要执行git add命令手动加入暂存区。



六、命令

 

  • git add
    • 添加到暂存区/索引。
  • git fetch
    • 下载远程版本库内容。

  • git merge
    • 合并分支到当前分支。

  • git pull
    • git fetch + git merge。

  • git reset HEAD
    • 取消已经缓存的内容。

  • git status
    • 查看需要添加到暂存区和已经添加到暂存区但是还没有提交的文件。

  • git remote [-v]
    • 显示目前项目的远程仓库。

  • git remote add aop git@git.coding.net:**co**/AOP.git
    • 添加远程仓库,其中aop是自定义的远程仓库名称。

  • git pull aop master
    • 从远程仓库aop中的master分支pull新的数据。

  • git push aop master
    • push新的数据到到远程仓库aop 的master分支。


  • 注意
    • GIT命令不区分大小写。



七、分支

 

  • 合并不仅仅是简单的文件添加、移除的操作,也会合并修改(当在合并修改的时候出现冲突就要解决冲突);
  • 其他
    • 分支作用
      • 使用分支意味着你可以从开发主线上分离开来,然后在不影响主线的同时继续工作。 即在没有合并之前,分支上的内容相互独立。
    • 解决冲突【pull/fetch/merge-> 手动解决冲突(即冲突“三元素”直接包括的内容) -> git add -> git commit】
    • pull/fetch(从远程到本地)或者git merge(本地版本库之间合并,一般不会出现冲突),有可能出现冲突(会用<<<<<<HEAD、======、>>>>>local这三者标注冲突内容,详细见下面分析),那么就要手动解决,然后要git add告诉GIT冲突已经解决了(此时如果直接commit,会提醒有冲突要先解决才能commit(普通没有冲突的文件如果过需要commit可以直接提交,这时候commit中包含了更新版本库,对于冲突文件必须要先添加到的索引中才可以commit))
    • <<<<<HEAD、======、>>>>>local含义和作用
    • <<<<HEAD(索引)和====之间代表索引里面指向的内容,而====和>>>>local(本地)之间代表的则是本地内容

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值