作者热门文章
- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我找不到我的问题的任何相关答案。我现在有两个分支:
大师
开发
提交并推送到服务器所有修改(到 develop
分支)后,我想用 develop
分支更新 master
分支。不小心我搞砸了,在 merge master
和 develop
之后 - master
现在拥有两个分支的所有内容,这不是我想要的.
如何恢复本地存储库中的所有内容?我试过 git reset --hard HEAD
但它似乎没有帮助。
最佳答案
解决方案一:
如果您发现当时的提交,您可以将您的分支重置为 merge 之前的状态。
使用 git reflog
,它将列出您拥有的所有 HEAD。我发现 git reflog --relative-date
非常有用,因为它显示了每次更改发生的时间。
一旦你发现那个提交就做一个git reset --hard <commit id>
你的分支将像以前一样。
你可以简单地git revert
像这样 merge 提交:
git checkout BRANCH_NAME
git revert -m 1 <merge_commit_sha>
注意:您可能会遇到一些必须手动取消 merge 的冲突,就像正常 merge 时一样。
关于Git - 搞砸后回滚所有本地更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43604183/
我是一名优秀的程序员,十分优秀!