我正在一个git分支上工作,并准备提交我的更改,所以我用一个有用的提交消息做了一个提交。然后,我心不在焉地对代码做了一些不值得保留的小更改。我现在想改变分支,但是git给了我,
错误:您对“X”进行了本地更改;不能切换分支。
我可以在不提交的情况下更改分支吗?如果是,我该如何设置呢?如果不是,我该如何解决这个问题?我想在不提交的情况下忽略较小的更改,只更改分支。
我正在一个git分支上工作,并准备提交我的更改,所以我用一个有用的提交消息做了一个提交。然后,我心不在焉地对代码做了一些不值得保留的小更改。我现在想改变分支,但是git给了我,
错误:您对“X”进行了本地更改;不能切换分支。
我可以在不提交的情况下更改分支吗?如果是,我该如何设置呢?如果不是,我该如何解决这个问题?我想在不提交的情况下忽略较小的更改,只更改分支。
当前回答
注意,如果你合并了远程分支或者有本地提交,想要回到远程HEAD,你必须做:
git reset --hard origin/HEAD
HEAD单独只会引用本地提交/合并——有几次我忘记了在重置时,当我完全打算破坏所有更改/提交并返回远程分支时,我以“您的存储库是X提交前..”结束。
其他回答
简单的答案:
是强制签出分支吗
git checkout -f <branch_name>
强制签出分支是告诉git放弃当前分支中所做的所有更改,并签出所需的分支。
或者万一你在检查一个提交
git checkout -f <commit-hash>
“我认为我可以不用承诺就可以改变分支。如果是,怎么做 我能安排一下吗?如果不是,我该如何解决这个问题?”
答案是否定的,这就是Git的哲学,你要跟踪所有的更改,并且每个节点(即提交)必须与你所做的最新更改保持一致,当然,除非你已经进行了新的提交。
你决定留着零钱?
然后把它们藏起来
git stash
然后使用
git stash apply
这将应用你的变化,但保持他们在stash队列太。如果你不想把它们放在藏物堆里,那就用它们把它们弹出
git stash pop
这相当于apply然后drop
跟进,
$: git checkout -f
$: git checkout next_branch
这些答案都没有帮助我,因为即使在重置和保存之后,我仍然有未跟踪的文件。我必须这么做:
git reset --hard HEAD
git clean -d -f
如果您想放弃更改,
git checkout -- <file>
git checkout branch
如果你想保留这些变化,
git stash save
git checkout branch
git stash pop
当git stash不工作时,切换到其他分支而不提交更改。您可以使用以下命令:
Git checkout -f branch-name