我正在一个git分支上工作,并准备提交我的更改,所以我用一个有用的提交消息做了一个提交。然后,我心不在焉地对代码做了一些不值得保留的小更改。我现在想改变分支,但是git给了我,

错误:您对“X”进行了本地更改;不能切换分支。

我可以在不提交的情况下更改分支吗?如果是,我该如何设置呢?如果不是,我该如何解决这个问题?我想在不提交的情况下忽略较小的更改,只更改分支。


当前回答

如果您希望保留更改并在单行命令中更改分支

git stash && git checkout <branch_name> && git stash pop

其他回答

为了你精神上的平静 (为了更容易地访问你做分支切换时未提交的更改)

在切换之前:

git checkout <next_branch>

use

git stash save "brief description of changes"

而不是默认值:

git stash    
// or
git stash save

如果你的git隐藏列表是一个较长的列表,这是值得的 必须回到之前的某个想法。

关闭终端,删除项目所在的文件夹,然后再次克隆您的项目和voilá。

这些答案都没有帮助我,因为即使在重置和保存之后,我仍然有未跟踪的文件。我必须这么做:

git reset --hard HEAD
git clean -d -f

嗯,应该是这样

git stash save
git checkout branch
// do something
git checkout oldbranch
git stash pop

注意,如果你合并了远程分支或者有本地提交,想要回到远程HEAD,你必须做:

git reset --hard origin/HEAD

HEAD单独只会引用本地提交/合并——有几次我忘记了在重置时,当我完全打算破坏所有更改/提交并返回远程分支时,我以“您的存储库是X提交前..”结束。