- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我试图在 git 中撤消我的提交。使用 git reset --hard HEAD~1
有危险吗?
git reset
的不同选项有什么区别?
最佳答案
git reset
知道五种“模式”:软、混合、硬、 merge 和保留。我将从前三个开始,因为这些是您通常会遇到的模式。之后你会发现一个不错的小奖励,敬请期待。
假设您有一个具有类似于此历史记录的存储库:
7e05a95 (HEAD -> main) Update a
e62add5 Update b
ca9ae0a Update a
9b6060d Add c
eebe372 Add b
947586a Add a
最新的提交 (7e05a95
) 包含这些更改:
diff --git a/a b/a
index b66ba06..28b68e2 100644
--- a/a
+++ b/a
@@ -1 +1 @@
-new content
+new new content
现在,当您在各种不同的模式下运行 git reset
时会发生什么?让我们找出答案!
当使用 git reset --soft HEAD~1
时,您将从当前分支中删除最后一次提交,但文件更改将保留在您的 working tree 中。 .此外,更改将保留在您的索引中,因此使用 git commit
将创建一个与您之前“删除”的提交具有完全相同更改的提交。
这在实践中会是什么样子?像这样:
> git reset --soft HEAD^ # Assuming HEAD points at 7e05a95
> git status
On branch main
Changes to be committed:
(use "git restore --staged <file>..." to unstage)
modified: a
如您所见,文件 a
中的更改已在索引中,并准备好再次提交。
这是默认模式,与软模式非常相似。当使用 git reset HEAD~1
“删除”一个提交时,你仍然会在你的工作树中保留更改,但不会保留在索引中;所以如果你想“重做”提交,你必须在提交之前添加更改(git add
)。
在实践中,结果可能是这样的:
> git reset --mixed HEAD^ # Assuming HEAD points at 7e05a95
> git status
On branch main
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: a
no changes added to commit (use "git add" and/or "git commit -a")
文件 a
的更改仍然存在,但它们不在索引中。
当使用 git reset --hard HEAD~1
时,除了上次提交中引入的更改外,您还将丢失所有未提交的更改和所有未跟踪的文件。更改不会保留在您的工作树中,因此执行 git status
命令会告诉您您的存储库中没有任何更改。
仔细阅读这个。如果您不小心删除了从未被 git
跟踪的未提交更改(说:已提交或至少已添加到索引),您无法使用 git
取回它们。
一个实际的例子可能是这样的:
> git reset --hard HEAD^ # Assuming HEAD points at 7e05a95
> git status
On branch main
nothing to commit, working tree clean
如您所见,没有任何更改。假设您在文件 b
中也有一些未提交的更改,这些更改也会丢失!
> echo 'some uncommitted changes' > b
> git status
On branch main
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: b
no changes added to commit (use "git add" and/or "git commit -a")
> git reset --hard HEAD^ # Assuming HEAD points at 7e05a95
> git status
On branch main
nothing to commit, working tree clean
git reset --keep HEAD~1
是一个有趣且有用的方法。它只重置 current HEAD
和给定提交之间不同的文件。如果这些文件中的一个或多个有未提交的更改,它将中止重置。它基本上是一个更安全的 hard
版本。
让我们回顾一下之前的示例,您在 b
中有一些未提交的更改:
> echo 'some uncommitted changes' > b
> git status
On branch main
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: b
no changes added to commit (use "git add" and/or "git commit -a")
> git reset --keep HEAD^ # Assuming HEAD points at 7e05a95
> git status
On branch main
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: b
no changes added to commit (use "git add" and/or "git commit -a")
您删除了文件 a
中的更改,但保留了文件 b
中未提交的更改!
因此重申:“hard”将删除所有更改,而“keep”仅从重置提交中删除更改。
这些模式中的每一种都在 git reset documentation 中进行了深入解释。 .
注意
当执行 git reset
删除提交时,提交并没有真正丢失,只是没有指向它或它的任何子项的引用。您仍然可以通过找到它的 SHA-1 key 来恢复使用 git reset
“删除”的提交,例如使用 git reflog
之类的命令。
关于git - 'git reset --hard HEAD~1' 和 'git reset --soft HEAD~1' 有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24568936/
每次暂存文件时,如果您需要取消暂存文件,Git 都会提供有用的说明: (use "git reset HEAD ..." to unstage) 不过体面Git Tutorials by Atlass
我需要添加几个文件以将它们组合到一个提交中,但我必须排除其中一个。在 this answer ,执行此操作的代码是: git add -u git reset -- file_to_ignore.da
这个问题在这里已经有了答案: What are typical use cases of git-reset's --merge and --keep flags? (4 个答案) 关闭 6 年前。
有时候,进行了错误的提交,但是还没有push到远程分支,想要撤销本次提交,可以使用git reset –-soft/hard命令。 1、二者区别: git reset –-soft:回退到某个版
我认为:软重置:从重置向量启动。硬复位:拉CPU的电平。 最佳答案 硬复位当然意味着整个CPU芯片及其所有外设都被复位。造成这种情况的原因可能有很多:复位引脚被外部拉高、时钟故障、片内低电压检测、看门
$python manage.py reset Unknown command: 'reset' Type 'manage.py help' for usage. 在django 1.6中是否取消了这
我是 git 的新手,所以问题可能很简单,git reset --hard HEAD 和 git reset --hard 有什么区别? 最佳答案 HEAD 在您未指定该参数时是隐含的。 但是,您可以
我使用 apollo-link-state 来本地存储错误,但清除缓存后出现以下错误。 我已在 apollo 客户端配置选项中将 errors 的默认值设置为空数组 []。 但是,在 apolloCl
我正在使用 bool 数组来存储标志(类似于“已更改”)。数组的大小是静态的,在编译时已知。 我需要定期重置数组,即将所有元素设置为 false。我应该使用常规数组和类似 memset 或 memcp
在 git 文档(和许多 SO 线程)中,推荐使用这种重置方法: $ git reset --soft HEAD^ ;# go back to WIP state $ git reset
在我的实验中,我没能发现两者之间的任何功能差异 git reset --hard 和 git reset --merge 使用说明也没有给出任何提示 --hard res
如何重置所有列过滤器?调用 reset() 似乎重置了表,但过滤器的所有字段保持不变。 最佳答案 您可以将输入值绑定(bind)到表的过滤器,如下所示: 注意 [value] 绑定(bind)。 关
使用 std::unique_ptr::reset,您可以轻松地将您的实例恢复到新状态。 C++11 之前,为了实现类似的行为,我看到很多类都定义了一个 Reset() 方法来重置其所有内部成员。但现
为了恢复工作树和索引中的更改,此答案 ( https://stackoverflow.com/a/5812972/8278160) 建议运行以下命令: git reset --hard 运行它是否与运
我目前正在测试竞技场。我本来以为这段代码会编译,但在运行时失败了,令人惊喜的是,编译器发现了这个问题。但我不知道它的推理是否正确。有人能给我解释一下吗?。错误:。来自umpalo的相关代码:
我目前正在测试竞技场。我本来以为这段代码会编译,但在运行时失败了,令人惊喜的是,编译器发现了这个问题。但我不知道它的推理是否正确。有人能给我解释一下吗?。错误:。来自umpalo的相关代码:
我正在尝试在不触发“重置”事件的情况下重置我的收藏。我已经设置了我的收藏来收听“重置”和“添加”事件 @.listenTo(@options.muses, 'add', @addOne) @.list
根据http://en.cppreference.com/w/cpp/memory/unique_ptr/reset , void reset( pointer ptr = pointer() );
我有一个别名,unstage,用于从暂存区域中删除更改。 unstage = reset -- 我注意到 git 的帮助建议改为 git reset HEAD。我还注意到 git rm --cache
这个问题在这里已经有了答案: What's the difference between HEAD^ and HEAD~ in Git? (17 个答案) 关闭 6 年前。 git reset --
我是一名优秀的程序员,十分优秀!