网站首页 > 基础教程 正文
让程序回到提交前的样子:两种解决方法:回退(reset)、反做(revert)
方法一:git reset
原理: git reset的作用是修改HEAD的位置,即将HEAD指向的位置改变为之前存在的某个版本
适用场景: 如果想恢复到之前某个提交的版本,且那个版本之后提交的版本我们都不要了,就可以用这种方法。
具体操作:
1. 查看版本号:可以使用命令“git log”查看:
2. 使用“git reset --hard 目标版本号”命令将版本回退
再用“git log”查看版本信息,此时本地的HEAD已经指向之前的版本:
3. 使用“git push -f”提交更改:此时如果用“git push”会报错,因为我们本地库HEAD指向的版本比远程库的要旧
方法二:git revert
原理: git revert是用于“反做”某一个版本,以达到撤销该版本的修改的目的。比如,我们commit了三个版本(版本一、版本二、 版本三),突然发现版本二不行(如:有bug),想要撤销版本二,但又不想影响撤销版本三的提交,就可以用 git revert 命令来反做版本二,生成新的版本四,这个版本四里会保留版本三的东西,但撤销了版本二的东西。
适用场景: 如果我们想撤销之前的某一版本,但是又想保留该目标版本后面的版本,记录下这整个版本变动流程,就可以用这种方法。
1. 查看版本号:
2.使用“git revert -n 版本号”反做,并使用“git commit -m 版本名”提交:
(1)反做,使用“git revert -n 版本号”命令。如下命令,我们反做版本号为8b89621的版本:
git revert -n 8b89621019c9adc6fc4d242cd41daeb13aeb9861
注意: 这里可能会出现冲突,那么需要手动修改冲突的文件。而且要git add 文件名。
(2)提交,使用“git commit -m 版本名”,如:
git commit -m "revert add text.txt"
此时可以用“git log”查看本地的版本信息,可见多生成了一个新的版本
3.使用“git push”推上远程库
猜你喜欢
- 2025-04-30 代码管理工具git操作全总结(基于git的代码托管及版本控制)
- 2025-04-30 8、表单控制:预言水晶球——React 19 复杂表单处理
- 2025-04-30 「转」CS可视化:有用的Git命令(git可视化管理页面)
- 2025-04-30 看完这篇轻松玩转Git:详细、浅显、易学
- 2025-04-30 Git重置到某个历史节点(Sourcetree工具)
- 2025-04-30 git撤销commit(git撤销commit但不改变文件)
- 2025-04-30 Java开发人员的版本控制技能:Git的趣味之旅
- 2025-04-30 GIT,如何恢复修改过的文件,回到过去呢?
- 2025-04-30 git工作区、暂存区、本地仓库、远程仓库的区别和联系
- 2025-04-30 Git从入门到精通:拯救你的代码仓库的终极指南
- 最近发表
- 标签列表
-
- 菜鸟教程 (58)
- jsp (69)
- c++教程 (58)
- pythonlist (60)
- gitpush (78)
- gitreset (66)
- pythonif (68)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)