目的
学习如何还原已经提交到本地仓库的更改。
撤销提交
有时候你意识到已经提交的更改不正确并想撤销该提交。有几种方式可以处理这种问题,我们在本实验中所用的方式总是安全的。
实际上我们将通过创建新的提交来撤销原来不想要更改的提交。
更改文件并提交
更改 hello.rb 文件成下列内容:
# This is an unwanted but committed change
name = ARGV.first || "World"
puts "Hello, #{name}!"
$ git add hello.rb
$ git commit -m "Oops, we didn't want this commit"
创建还原提交
要撤销已提交的更改,我们需要创建一个提交来移除由不想要的提交所引入的更改。
$ git revert HEAD
这将带你到编辑器中。你可以编辑默认的提交信息,或直接离开它。保存并关闭文件。你应该看到:
$ git revert HEAD --no-edit
[master a10293f] Revert "Oops, we didn't want this commit"
1 files changed, 1 insertions(+), 1 deletions(-)
因为我们将撤销我们做的最后提交,所以我们可以使用 HEAD
作为还原的参数。通过简单的指定哈希值,我们可以撤销早期历史中的任意提交。
注意:命令中的 --no-edit
可被忽略。在不打开编辑器生成输出时需要它。
检查日志
检查日志来显示我们仓库中不想要及还原的提交。
$ git hist