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

本文详细介绍了Git的四个工作区域和五种状态,包括如何查看文件状态及撤销修改的方法。重点讨论了`git reset`与`git revert`的区别,`git reset`是直接删除提交,而`git revert`则是通过新提交来覆盖。同时提到了`git reset`的不同模式(soft、hard、mixed)。最后提供了相关参考资料。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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.youkuaiyun.com/alphapersonality/article/details/80581730

git官方文档:

https://git-scm.com/doc

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值