五种状态间的顺序操作

四个区

  1. 工作区(Working Area)

  2. 暂存区(Stage)

  3. 本地仓库(Local Repository)

  4. 远程仓库(Remote Repository)

五种状态

  1. 未修改(Origin)

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

  3. 已暂存(Staged)

  4. 已提交(Committed)

  5. 已推送(Pushed)

顺序操作

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

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

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

    640?wx_fmt=png

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

    640?wx_fmt=png

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

    640?wx_fmt=png

640?wx_fmt=png

五种状态间的撤销操作

已修改,但未暂存

640?wx_fmt=png

已暂存,未提交

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

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

640?wx_fmt=png

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

已提交,未推送

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

640?wx_fmt=png

已推送到远程

640?wx_fmt=png

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

总结

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

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

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

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

版权申明:内容来源网络,版权归原创者所有。如有侵权烦请告知,我们会尽快删除并表示歉意。谢谢。原文链接:

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

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐