在我的一个开发分支中,我对代码库做了一些更改。在我能够完成正在开发的功能之前,我必须将当前分支切换到master来演示一些功能。但仅仅使用“git checkout master”就保留了我在开发分支中所做的更改,从而破坏了master中的一些功能。因此,我所做的是在我的开发分支上提交一条提交消息“临时提交”,然后为演示签出主控。

现在,我已经完成了演示并返回到我的开发分支中,我想删除我所做的“临时提交”,同时仍然保留我所作的更改。这可能吗?


当前回答

使用git2.9(精确到2.9.2.windows.1)git reset HEAD^提示更多信息;不确定此处的预期输入。请参考下面的截图

找到了另一个解决方案git-resetHEAD~#numberOfCommits,我们可以使用它来选择要通过保持更改不变来重置的本地提交数。因此,我们有机会丢弃所有本地提交以及有限数量的本地提交。

请参阅下面显示git reset HEAD~1的屏幕截图:

其他回答

我想你在找这个

git reset—软HEAD~1

它撤消最近的提交,同时将该提交中所做的更改保留到登台。

还有一种方法。

在临时提交的顶部添加提交,然后执行以下操作:

git rebase -i

要将两个提交合并为一个(命令将打开带有显式指令的文本文件,请对其进行编辑)。

是的,您可以在不删除更改的情况下删除提交:

git reset @~

您正在查找git reset HEAD^--soft或git reset-HEAD^-mixed。

如文档中所述,重置命令有三种模式:

git reset HEAD^--软

撤消git提交。更改仍然存在于工作树(项目文件夹)+索引(--cached)中

git reset HEAD^--混合

撤消gitcommit+gitadd。工作树中仍存在更改

git reset HEAD^--硬

就像你从未对代码库做过这些更改一样。更改将从工作树中删除。

如果您想更新提交的历史记录,或者想添加新的提交并删除以前的提交,请使用此代码

此命令将打印最后一个提交散列,例如fa386d8eaa4bde4a4a2912ef96aad6df31f4d4ccgit日志重置上次提交。注意:它不会删除任何更改并保留新的和旧的更改。仅删除最后一条提交消息数字重置629f9dfb47620a1794f5edf816762f8e30668498添加所有更改的文件git添加。提交您的邮件gitcommit-m“Your_new_commit_message_here”强制推送之前已经推送的内容,并使用相同的gitlog命令进行检查git push-f源Your_Branch_Name