Git 回退代码的两种方法对比

Git 回退代码版本

在项目的开发中,有时候还是会出现,一些误提交了一些代码,这时候就会想撤回提交的代码,在Git中有两种方法可以使用,现在通过对比方法比较这两种方法的区别,分别适用于哪些情况?

在Git中回退代码,经常使用revert或者reset来做,这两种操作都可以用来回退,但是却有比较大的区别,一般比较安全性的还是使用revert来做,revert是撤回对应的提交记录,然后再提交撤回记录,只是会在Git历史里多一些记录,reset的操作是直接将git历史回退到对应的版本,之后的记录全都撤回了,所以除非情况允许,不然不建议使用

git revert操作

git revert:revert撤回的意思,意思是撤回提交的代码,然后在Git的所有提交记录后面新增一次提交,不会撤回之前的代码,所以是很安全性的撤回方法,不过就会新增一次撤回记录

git revert使用方法:

shell 复制代码
# 撤回指定版本,后面可以加一个git记录id
git revert [版本ID]
# 撤回上个版本的提交
git revert HEAD^
# 撤回上上个版本提交
git revert HEAD^^
# 或者写成
git revert HEAD^2

如果有git客户端软件,比如smartgit,可以直接在ui界面操作

然后再提交上去,重新生成一次撤回记录

git reset 操作

git reset :reset,重置操作,是重置HEAD的位置,将代码重置到某个版本,某个版本之后的提交都会被清掉,所以不是很安全,非特殊情况,不建议使用

git reset的语法格式为:

shell 复制代码
git reset [--soft | --mixed | --hard] [HEAD]
  • --mixed(默认):默认的参数,将重置的更改留在工作区中

  • --soft:如果使用 --soft 参数,将重置的更改保存在暂存区

  • --hard参数:如果使用 --hard 参数,工作区和暂存区都不会保存记录,所以建议不要使用这种模式

OK,下面使用git命令实践一下

shell 复制代码
# 找到要回退的commit版本号,复制
git log 
# 重置本地库版本回退
git reset --mixed [commitid] 
# 同步到远端仓库,要写上分支名称
git push -f origin [branchName] 
相关推荐
大、男人4 小时前
分享一个git设备代理的方法
git
悟悟悟!4 小时前
git使用笔记:git日常工作流和命名规范
笔记·git·elasticsearch
漏洞文库-Web安全4 小时前
CTFHub 信息泄露通关笔记9:Git泄露 Index - 指南
笔记·git·安全·web安全·elasticsearch·网络安全·ctf
weixin_307779135 小时前
深度解析 Jenkins Git Client 6.4.0 插件:核心功能、应用场景与最佳实践
运维·git·架构·jenkins
終不似少年遊*5 小时前
【Git使用】Git 团队开发常用命令汇总手册
git·团队开发·开发工具·使用手册·项目提交
郑州光合科技余经理13 小时前
同城系统海外版:一站式多语种O2O系统源码
java·开发语言·git·mysql·uni-app·go·phpstorm
郑州光合科技余经理16 小时前
基于PHP:海外版同城O2O系统多语言源码解决方案
java·开发语言·git·spring cloud·uni-app·php·uniapp
Violet_YSWY17 小时前
git变基删除中间版本,使用drop出现文件丢失问题,原因及解决方案
git
dragonchow12319 小时前
git sparse-checkout, 只拉取部分目录
git
醇氧21 小时前
Git 合并冲突提示 Local Changes Prevent from Merge
运维·git