Git的四个区五种状态

五种状态间的顺序操作

四个区

  1. 工作区 (Working Area)

  2. 暂存区 (Stage)

  3. 本地仓库 (Local Repository)

  4. 远程仓库 (Remote Repository)

五种状态

  1. 未修改 (Origin)

  2. 已修改 (Modified)& 未追踪 (Untracked)

  3. 已暂存 (Staged)

  4. 已提交 (Committed)

  5. 已推送 (Pushed)

顺序操作

  1. 第零步:工作区与仓库保持一致

  2. 第一步:文件增删改,变为已修改状态

  3. 第二步:git add ,变为已暂存状态

$ git add --all # 当前项目下的所有更改 
$ git add . # 当前目录下的所有更改 
$ git add xx/xx.py xx/xx2.py # 添加某几个文件

第三步:git commit,变为已提交状态

$ git commit -m"<这里写commit的描述>"

第四步:git push,变为已推送状态

$ git push -u origin master # 第一次需要关联上 
$ git push # 之后再推送就不用指明应该推送的远程分支了 
$ git branch # 可以查看本地仓库的分支 
$ git branch -a # 可以查看本地仓库和本地远程仓库(远程仓库的本地镜像)的所有分

git1.png

五种状态间的撤销操作

已修改,但未暂存

$ git diff # 列出所有的修改 
$ git diff xx/xx.py xx/xx2.py # 列出某(几)个文件的修改
$ git checkout # 撤销项目下所有的修改 
$ git checkout . # 撤销当前文件夹下所有的修改 
$ git checkout xx/xx.py xx/xx2.py # 撤销某几个文件的修改 
$ git clean -f # untracked状态,撤销新增的文件 
$ git clean -df # untracked状态,撤销新增的文件和文件夹 

# Untracked files: 
# (use "git add <file>..." to include in what will be committed) 
# 
# xxx.py

已暂存,未提交

这个时候已经执行过 git add,但未执行 git commit,但是用 git diff 已经看不到任何修改。

因为 git diff 检查的是工作区与暂存区之间的差异。

$ git diff --cached # 这个命令显示暂存区和本地仓库的差异
$ git reset # 暂存区的修改恢复到工作区 
$ git reset --soft # 与git reset等价,回到已修改状态,修改的内容仍然在工作区中 
$ git reset --hard # 回到未修改状态,清空暂存区和工作区

git reset --hard 操作等价于 git reset 和 git checkout 2 步操作

已提交,未推送

执行完 commit 之后,会在仓库中生成一个版本号 (hash 值),标志这次提交。之后任何时候,都可以借助这个 hash 值回退到这次提交

$ git diff <branch-name1> <branch-name2> # 比较2个分支之间的差异 
$ git diff master origin/master # 查看本地仓库与本地远程仓库的差异
$ git reset --hard origin/master # 回退与本地远程仓库一致 
$ git reset --hard HEAD^ # 回退到本地仓库上一个版本 
$ git reset --hard <hash code> # 回退到任意版本 
$ git reset --soft/git reset # 回退且回到已修改状态,修改仍保留在工作区中。

已推送到远程

$ git push -f orgin master # 强制覆盖远程分支 
$ git push -f # 如果之前已经用 -u 关联过,则可省略分支名

慎用,一般情况下,本地分支比远程要新,所以可以直接推送到远程,但有时推送到远程后发现有问题,进行了版本回退,旧版本或者分叉版本推送到远程,需要添加 -f 参数,表示强制覆盖。

总结

  1. 首先,先用 git status 查看下当前状态。

  2. git reset 可以作用于本地仓库,用于回退 / 前进到任意版本,也可以作用于暂存区,用于撤销暂存区修改。有 hard 和 soft2 个参数。soft 参数可以省略,soft 参数表示撤销的修改仍放在工作区中。

  3. git checkout 用于撤销删除和修改,git clean -df 用于撤销新增。

  4. git diff 可以查看工作区、暂存区、仓库之间的修改和差异,参数不同。



爱代码,爱熬夜,爱咖啡可乐。

爱挑战,爱钻研,爱打游戏。

爱晚起,也爱工作到深夜。

我崇拜技术,崇尚简单和懒惰。

我神秘而孤僻,沉默而爱憎分明。

我是程序员,但是我不是没有感情。



转载自:https://geektutu.com/post/git-four-areas-five-states.html

声明:禁止任何非法用途使用,凡因违规使用而引起的任何法律纠纷,本站概不负责。

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

精彩评论

全部回复12人评论7,777人参与