Git undo 操作

简介:

相比传统的版本管理工具,git 的 undo 操作也不是很简单明了,本文尝试总结常用的 undo 操作。

重新提交

应该避免考虑不周全的提交,但这太难了。因此Git 专门提供了一个命令来弥补粗心的提交导致的问题。说白了就是让你重新提交一次。

$ git commit --amend

这个命令会重新提交暂存区中的内容。因此你可以重新考虑哪些文件需要提交,并且把这次提交用的comment准备好。

 

为了更好的理解这个命令,我们看看它是怎么工作的。

它相当于下面的两条命令:

$ git reset --soft head^
$ git commit -e -F .git/COMMIT_EDITMSG

第一条命令让头指针指向上次的提交,并且不改变暂存区和工作区。

第二条命令是重新提交,并且强制输入提交说明。

回滚暂存区中的变更

我们希望每次提交都是一个相对完整的整体。所以很多时候是提交所有变更文件中的一部分。

举个简单的例子,当前修改了两个文件,希望把它们包含到不同的提交中。所以问题就来了,我们习惯了使用

git add -u 或者 git add . 这样的命令,一不留神就把所有的修改文件添加到了暂存区。

其实git已经很殷勤的告诉我们该怎么做了:

$ git reset head begin.txt

好了再用 git status 命令看看,begin.txt 此时已经离开了暂存区。

回滚工作区中的变更

这是一个很危险的操作,因为这真的会丢掉工作区中的变更,并且是找不回来的。在产生这个念头时,一定要三思!至于具体的操作,Git 也为我们提供了详细的指导:

$ git checkout -- begin.txt

再看看工作区,begin.txt 文件已经被回滚了。


本文转自sparkdev博客园博客,原文链接:http://www.cnblogs.com/sparkdev/p/5792356.html,如需转载请自行联系原作者

相关文章
|
9月前
|
Ubuntu 开发工具 git
git 超实用教程【人人必会!】(含大厂的 git 操作规范)
git 超实用教程【人人必会!】(含大厂的 git 操作规范)
187 0
|
10月前
|
开发工具 git
idea的git reset current branch to here操作详解
idea的git reset current branch to here操作详解
981 1
|
11月前
|
开发工具 git 开发者
掌握常见Git操作:技巧与实践
掌握常见Git操作:技巧与实践
|
11月前
|
开发工具 git 开发者
【专栏】探讨了 Git 中的 `git rebase` 操作,它用于重新应用提交到另一分支,改变历史顺序
【4月更文挑战第29天】本文探讨了 Git 中的 `git rebase` 操作,它用于重新应用提交到另一分支,改变历史顺序。与 `git merge` 不同,rebase 重写提交历史,提供简洁线性的历史记录。文章介绍了 rebase 的基本操作、应用场景,如整理提交历史、解决冲突和整合分支,并强调了使用注意事项,如避免在公共分支上操作。尽管 rebase 可以带来整洁的历史和冲突解决便利,但其潜在的风险和可能导致的历史混乱需谨慎对待。理解并恰当使用 `git rebase` 可以提升开发效率和代码质量。
319 1
|
11月前
|
Linux 开发工具 git
还不会 Git 子模块操作?一文教你学会 git submodule 的增、删、改、查!
还不会 Git 子模块操作?一文教你学会 git submodule 的增、删、改、查!
250 0
|
11月前
|
开发工具 git
记IDEA Git版本回退并push到远程操作
记IDEA Git版本回退并push到远程操作
231 1
记IDEA Git版本回退并push到远程操作
|
11月前
|
开发工具 git 开发者
深入解析:取消 Git Pull 操作的完整指南
【2月更文挑战第29天】
1083 0
|
11月前
|
开发工具 git
|
11月前
|
开发工具 git
web后端-IDEA的Git操作
web后端-IDEA的Git操作
|
11月前
|
存储 持续交付 开发工具
Git操作入门
Git是一个的开源分布式版本控制系统,它已经被广泛应用于软件开发、文档管理、代码托管等领域,成为当今最流行的版本控制系统之一。Git通过高效地管理文件的变化,使得团队协作更加高效,错误率更低。本文将介绍Git的工作原理、基本命令和常见用法等内容。
70 0
Git操作入门

相关实验场景

更多