一、Git使用机制
Git的区域分为工作区,缓存区,本地仓库区
工作区: 就是本地开发项目的根目录
缓存区: 版本库中设立一个暂存区(Stage or Index),作为用来直接跟工作区的文件进行交互,工作区文件的提交或者回滚首选都是通过暂存区,而版本库中除了暂存区之外,文件的提交的最终存储位置是分支(Branch),在创建版本库的时候默认都会有一个主分支(Master)。
本地仓库: 我们在为项目添加本地库之后,会在工作区生成一个如下图所示的隐藏目录“.git”,.git目录即为当前工作区的本地版本库
- git add files:把当前工作文件拷贝到暂存区
- git commit:在缓存区 生成文件快照并 提交到本地仓库
- git reset – files:撤销最后一次 git add files
- git reset:撤销所有缓存区文件
- git checkout – files:把文件从暂存区域覆盖到工作目录,用来丢弃本地修改。
其中,reset操作是将暂存区内选中的目标文件从暂存区中丢弃,不影响其他任何区域的文件,等同于一个自刷新的动作
相关命令:
- 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会用
<<<<<<<
,=======
,>>>>>>>
标记出不同分支的内容