Git命令图解、Git命令撤销、Git命令reset与revert对比

4个区域:

工作区(Working Area)    Working Copy

暂存区(Stage)    Index

本地仓库(Local Repository)    HEAD

远程仓库(Remote Repository)    HEAD

5种状态:

未修改(Origin)

已修改(Modified)

已暂存(Staged)

已提交(Committed)

已推送(pushed)

查看区别与撤销方法:

git diff 已修改,未暂存,即还没有执行git add .

git checkout .  或者  git reset –hard

 

git diff --cached 已暂存,未提交,即已经执行了git add . 但没有执行git commit –m “comment”

git reset(将修改退回到git add . 之前的状态,即已修改未暂存) git checkout .(退回到未修改)

或者 git reset --hard(“一步到位”)

 

git diff master origin/master 已提交,未推送,即执行了git add .和git commit

git reset --hard origin/master

 

若git add .和git commit . 并且还git push了……

则需要强制恢复本地仓库,再强制push到远程仓库

git reset --hard HEAD^

git push –f

 

git revert 与 git reset的区别:

git revert HEAD 撤销前一次commit

git revert HEAD^ 撤销前前一次commit

git revert commit ID 撤销指定的版本

git reset是直接删除指定的commit

而git revert是通过新的提交覆盖之前的提交,且新的提交与被覆盖的提交操作互逆

即git reset是把HEAD向后回退,而git revert是把HEAD向前继续。

注意:两者效果表面一致,但在merge老版本的branch时,由于git reset 只是撤销当前的branch,所以老版本的branch中对应的commit会“再现”。但是由于git revert是增加逆向操作,所以可以覆盖老版本中的对应的commit,使其无法重现。

 

git reset参数解释:soft、hard、mixed(default)

https://www.cnblogs.com/kidsitcn/p/4513297.html

https://blog.csdn.net/alphapersonality/article/details/80581730

git官方文档:

https://git-scm.com/doc

参考链接:https://www.fengerzh.com/git-reset/

猜你喜欢

转载自blog.csdn.net/GZHarryAnonymous/article/details/82955956