Git使用理解

一、Git使用机制

git

git流程图
Git的区域分为工作区,缓存区,本地仓库区

工作区: 就是本地开发项目的根目录

缓存区: 版本库中设立一个暂存区(Stage or Index),作为用来直接跟工作区的文件进行交互,工作区文件的提交或者回滚首选都是通过暂存区,而版本库中除了暂存区之外,文件的提交的最终存储位置是分支(Branch),在创建版本库的时候默认都会有一个主分支(Master)。

本地仓库: 我们在为项目添加本地库之后,会在工作区生成一个如下图所示的隐藏目录“.git”,.git目录即为当前工作区的本地版本库

git工作区

  • git add files:把当前工作文件拷贝到暂存区
  • git commit:在缓存区 生成文件快照并 提交到本地仓库
  • git reset – files:撤销最后一次 git add files
  • git reset:撤销所有缓存区文件
  • git checkout – files:把文件从暂存区域覆盖到工作目录,用来丢弃本地修改。

其中,reset操作是将暂存区内选中的目标文件从暂存区中丢弃,不影响其他任何区域的文件,等同于一个自刷新的动作

git commit -a

相关命令:

  • git commit -a 连续执行git add和git commit,先把文件从工作目录复制到缓存区,再把它从缓存区复制到仓库中
  • git checkout HEAD – files 的过程刚好相反,将工作区和暂存区都同步至当前分支内的状态,也就是最后一次commit的状态
  • git diff 查看尚未暂存的文件更新了哪些部分;即当前状态下工作区和暂存区之间的差异。
  • git diff -cached 查看已暂存文件和上次提交时的快照之间的差异;即当前状态下暂存区和分支内的差异
  • git diff HEAD 查看未暂存文件与最新提交文件快照的区别;即当前状态下工作区和分支内的差异

撤销操作:

  • git commit –amend 撤销上一次提交,并将缓存区文件重新提交
  • git checkout –file 拉取缓存区文件,并将其替换成工作区文件
  • git reset HEAD –file 拉取最近一次提交到版本库的文件到缓存区,此操作不影响工作区

撤销操作

未缓存区转到缓存区:

  • git add file

缓存区提交到本地仓库

  • git commit -m

直接从工作区提交到本地仓库

  • git commit -am(只对已跟踪文件正确,新增文件出错)

本地库回退到缓存区

  • git reset –soft hash值
  • git reset -soft origin/master

本地库回退到文件初始状态

  • git reset -hard hash值

  • 注意这里,通常先执行一次fetch,保证本地版本是origin的最新版本,然后再回退。(最厉害的是,这么操作不会有冲突,直接让文件变成和origin保持一致)

    • git fetch origin
    • git reset –hard origin/master
    • 特别注意:这么操作会使你对文件的修改全部消失,还原成最初状态。
  • (针对上一条情况衍生讲解)通常在推送到origin时,先要pull,然后再推送,一般是修改提交了的文件和pull下来的同一个文件产生冲突(所以建议修改代码前,一定先要pull)

    • git pull

    • git push origin master

缓存区回退到未缓存区

  • git reset -files
  • git reset(撤销所有缓存区文件)

未缓存区回退到文件初始状态

  • git checkout – files

缓存区回退到文件初始状态

  • git checkout head -files

二、Git分支理解

这个功能的作用是,如果我们需要给项目添加一个新的功能,在代码没有写完的情况下,如果提交会导致项目组中其他成员无法使用项目代码,不提交会有损失项目进度的风险,我们就可以新开一个分支,然后完成功能之后再合并分支。

  • Git中主分支一般是master,HEAD指向的是当前分支,不断再master分支上提交代码,master分支也会越来越长
  • 创建一个新的分支other,然后切换到该分支工作,HEAD就会指向other,在other上提交代码就会导致other越来越长
  • 合并分支就是直接把master指向other当前提交,就完成了合并
  • 冲突

冲突

这种情况下git无法执行快速合并,只能手动解决冲突再提交

解决冲突之后提交

  • 分支常用指令
    • 查看分支 git branch
    • 创建分支 git branch name
    • 切换分支 git checkout name
    • 创建+切换分支 git checkout -b name
    • 合并某个分支到当前分支 git merge name
    • 删除分支 git branch -b name
    • 查看分支合并图 git log –graph
  • git会用 <<<<<<<=======>>>>>>>标记出不同分支的内容
© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享