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://www.fengerzh.com/git-reset/