git revert和reset区别

简介: 1.在github上建立测试项目并克隆到本地 2.本地中新建两个文本文件   3.将a.txt commit并push到远程仓库  执行 git add a.txt, git commit -m "a.

1.在github上建立测试项目并克隆到本地

2.本地中新建两个文本文件

 

3.将a.txt commit并push到远程仓库

 执行 git add a.txt, git commit -m "a.txt", git push

 

 

4.将b.txt提交到本地仓库,不执行push

 通过gitk命令查看提交历史如下:

情景:b.txt本来不想提交上去,但是不小心提交上去了,怎么办?

   方法1:git reset head~1

     方法2:指定回退到具体的提交版本ID

  ->使用 git log查看提交历史,如下:

  ->git reset 81375c780e076ed87f1f1d96c88664126aec01cd

  最终结果如下:


 通过gitk查看提交历史

本地项目变化

  方法3:git revert head,用一个新提交来消除一个历史提交所做的任何修改。

  最终结果如下:

通过gitk查看提交历史

本地项目变化

  相信你通过gitk查看提交历史,就会发现revert和reset的不同了,reset是将head往后退而revert执行后head继续前行。

5.新建的a.txt和b.txt全都push到远程仓库中

   a.txt和b.txt分别提交并push上去,结果如下:

通过gitk查看提交历史

远程仓库

  (1).如果执行reset操作

    执行 git reset head~1,结果如下:

  

    然后执行 git pull,结果如下:

  (2).如果执行revert操作

    执行 git revert head, 结果如下:

    然后执行 git pull, 结果如下:

    但是远程仓库中还是有 b.txt这个文件的,通过git status查看结果如下:

    通过git push 将刚才revert回滚修改的提交 push到远程仓库。最后,保持本地和远程的一致。

6.参考资料

  git reset revert 回退回滚取消提交返回上一版本

  git 撤销commit

目录
相关文章
|
移动开发 小程序 Linux
【Linux】Linux和Window下\r与\n的区别、git命令行的使用
目录 1. 回车换行符在Window下和在Linux下的区别: 1.1回车换行符: 1. 2.行缓冲区打印: 1.3进度条小程序 :
705 0
|
存储 算法 开发工具
git是什么?git的五个命令,git和svn的区别
git是什么?git的五个命令,git和svn的区别
346 0
|
开发工具 git
在使用git revert回滚提交时,如果想保留部分更改应该怎么做?
在使用git revert回滚提交时,如果想保留部分更改应该怎么做?
977 57
|
开发工具 git
git fetch和 pull的区别
`git fetch`和 `git pull`在Git中扮演着不同的角色,了解它们的区别和使用场景对于高效管理代码库至关重要。通过合理使用这两个命令,可以更好地控制代码合并过程,减少冲突,提高团队协作效率。
1215 97
|
开发工具 git
git fetch和 pull的区别
通过这些内容和示例,您可以系统地理解 `git fetch`和 `git pull`的区别,并在实际工作中灵活应用这两个命令,提高版本控制的效率。希望这些内容对您的学习和工作有所帮助。
1147 24
|
存储 安全 开发工具
Git 对比 SVN 的区别和优势
Git和SVN各有优劣,选择哪种工具取决于项目的具体需求和团队的协作模式。Git适合大型、复杂、需要频繁分支和合并操作的项目,而SVN则更适合小型项目和集中式团队协作。通过本文的对比分析,开发者可以更好地理解两者
1769 13
|
开发工具 git
git的rebase和merge的区别
通过这些内容和示例,您可以深入理解Git的 `rebase`和 `merge`操作及其区别,选择合适的方法进行分支管理,提高版本控制的效率和规范性。希望这些内容对您的学习和工作有所帮助。
3200 5
|
存储 前端开发 开发工具
git clone -mirror 和 git clone 的区别
git clone -mirror 和 git clone 的区别
|
存储 开发工具 git
Git和SVN有什么区别?
综上所述,选择Git还是SVN取决于项目的具体需求、团队规模以及工作习惯。Git因其高级特性和灵活性,成为了现代软件开发中更受欢迎的选择,而SVN在某些特定场景下仍保有一席之地。开发者应当根据实际情况,权衡两者之间的优劣,作出最适合项目的选择。
822 4
|
开发工具 git 索引
$ git revert -m v1.0.21 6003eb5f5b455f0a3dfb74f48f63878e7 error: option `mainline' expect
$ git revert -m v1.0.21 6003eb5f5b455f0a3dfb74f48f63878e7 error: option `mainline' expect