git reset和git revert

git resetgit revert详解

背景

程序员在编码开发提交代码的时候,经常会出现需要回退、回撤代码的情况,比如某个功能延期了,需要回退某个功能提交的代码,遇到这种情况的时候发现有不少工作很多年的程序员都不太清楚怎么处理,这也是令我有点意外的,为了更好的帮助哪些不了解怎么进行代码回退或者代码撤销的新老程序员,特意写了这篇文章,希望对大家有所帮助。遇到这种情况,我们今天的主角git resetgit revert就可以派上用场了。

git reset 详解

git reset命令的作用是将指定提交之后的内容从当前分支中移除,并将HEAD指针移动到指定提交,同时将当前分支指针移动到指定提交,并将之后的提交从历史中移除。

使用示例

bash 复制代码
# 回退到指定版本
git reset <commit-hash>

# 等同于 `git reset <commit-hash>`, `<commit-hash>`之后的提交内容都会保留到工作区
git reset --mixed <commit-hash>

# `<commit-hash>`之后的提交内容会保留到暂存区,但是工作区不会改变
git reset --soft <commit-hash>

# `<commit-hash>`之后的提交内容都不会被保留,直接被移除掉了
git reset --hard <commit-hash>

# 回退到上一个版本
git reset HEAD^

# 回退到上两个版本
git reset HEAD~2

常用选项

bash 复制代码
git reset -h

usage: git reset [--mixed | --soft | --hard | --merge | --keep] [-q] [<commit>]
   or: git reset [-q] [<tree-ish>] [--] <paths>...
   or: git reset --patch [<tree-ish>] [--] [<paths>...]

    -q, --quiet           be quiet, only report errors
    --mixed               reset HEAD and index
    --soft                reset only HEAD
    --hard                reset HEAD, index and working tree
    --merge               reset HEAD, index and working tree
    --keep                reset HEAD but keep local changes
    --recurse-submodules[=<reset>]
                          control recursive updating of submodules
    -p, --patch           select hunks interactively
    -N, --intent-to-add   record only the fact that removed paths will be added later

git reset <commit-hash> 使用的最多的三个命令是--mixed--soft--hard

--mixed(默认值)表示重置HEAD和index,也就是说<commit-hash>之后的提交内容都会保留到工作区

--soft表示只重置HEAD指针,也就是说<commit-hash>之后的提交内容会保留到暂存区,但是工作区不会改变

--hard表示重置HEAD、index和working tree,也就是说<commit-hash>之后的提交内容都不会被保留,直接被移除掉了

所以,如果想保留<commit-hash>之后的提交内容,最好使用mixed或者--soft,慎用--hard

注意事项

  • git reset命令适合在单人分支,比如自己专属的feature分支上使用,多人共享的分支,需慎用,防止不小心把别人提交的代码也回退了
  • 使用git reset命令会修改历史提交记录,所以不能直接使用git push推送提交到远程分支,需要使用git push -f命令,强制推送
  • 如果不慎使用了git reset --hard <commit-hash> 命令,导致<commit-hash>之后的提交内容都被移除了,可以使用git reflog命令查看最近90天的操作记录,找到需要回滚的提交记录<reset-hash>,然后再使用git reset <reset-hash>命令进行回退,注意git reflog操作记录默认只会保留90天

git revert 详解

git revert创建一个新的提交,用来撤销指定提交引入的更改,这样可以保留提交历史的完整性。

使用示例

bash 复制代码
# 撤销指定提交
git revert <commit-hash>

# 撤销多个非连续的提交 -n 代表不自动提交
git revert -n <commit-hash-1> <commit-hash-2>
git commit -m "Revert multiple commits"

# 撤销多个连续的提交
git revert -n <commit-hash-a>..<commit-hash-b>
git commit -m "Revert multiple commits"

# 使用`--abort`取消回撤
git revert --abort

使用-n选项,可以在一个提交中撤销多个提交,最后通过一次提交来保存这些撤销。

常用选项

bash 复制代码
git revert -h

usage: git revert [<options>] <commit-ish>...
   or: git revert <subcommand>

    --quit                end revert or cherry-pick sequence
    --continue            resume revert or cherry-pick sequence
    --abort               cancel revert or cherry-pick sequence
    --skip                skip current commit and continue
    --cleanup <mode>      how to strip spaces and #comments from message
    -n, --no-commit       don't automatically commit
    -e, --edit            edit the commit message
    -s, --signoff         add Signed-off-by:
    -m, --mainline <parent-number>
                          select mainline parent
    --rerere-autoupdate   update the index with reused conflict resolution if possible
    --strategy <strategy>
                          merge strategy
    -X, --strategy-option <option>
                          option for merge strategy
    -S, --gpg-sign[=<key-id>]
                          GPG sign commit

注意事项

  • 新的提交历史: git revert创建新的提交,而不会改变现有的提交历史,这对于已经共享的分支是一种安全的操作。
  • 冲突处理: 在执行git revert时可能会遇到冲突,需要解决冲突后再次提交。

区别比较

  • 影响范围: git reset会修改提交历史,影响之后的提交;而git revert则通过创建新的提交来撤销指定提交,保留了提交历史的完整性。
  • 共享分支: git reset应慎用于共享分支,因为它会修改提交历史;而git revert更适合在已经共享的分支上安全使用。

本文由mdnice多平台发布

相关推荐
前端宝哥15 小时前
10 个超赞的开发者工具,助你轻松提升效率
前端·程序员
XinZong18 小时前
【VSCode插件推荐】想准时下班,你需要codemoss的帮助,分享AI写代码的愉快体验,附详细安装教程
前端·程序员
Goboy1 天前
0帧起步:3分钟打造个人博客,让技术成长与职业发展齐头并进
程序员·开源·操作系统
JaxNext1 天前
不选总统选配色,这一票投给 CSS logo
前端·css·程序员
程序员鱼皮2 天前
刚毕业,去做边缘业务,还有救吗?
计算机·程序员·互联网·求职·简历
WujieLi3 天前
独立开发沉思录周刊:vol18.AI 正在成为无处不在的基础设施
程序员·设计·创业
_祝你今天愉快3 天前
重学Android:从位运算到二进制表示(零)
算法·程序员
肖哥弹架构3 天前
并发编程之同步/异步/回调/任务 工作流程分析图解
java·后端·程序员
袁庭新3 天前
云原生+AI核心技术&最佳实践
java·人工智能·ai·云原生·程序员·袁庭新
安妮的心动录4 天前
2024 Sep & Oct Review
程序员·年终总结