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

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

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


当前回答

当git stash不工作时,切换到其他分支而不提交更改。您可以使用以下命令:

Git checkout -f branch-name

其他回答

嗯,应该是这样

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

切换到一个新的分支丢失更改:

git checkout -b YOUR_NEW_BRANCH_NAME --force

切换到现有分支会丢失更改:

git checkout YOUR_BRANCH --force

将未提交的更改移动到新的分支

我为它创建了一个.gitconfig别名:

[alias]
spcosp = !"git stash push && git checkout \"$@\" && git stash pop --index #"

要更改为new-branch-name,请使用:

git spcosp new-branch-name

任何未提交的文件和索引更改都将被保留。

当git stash不工作时,切换到其他分支而不提交更改。您可以使用以下命令:

Git checkout -f branch-name

如果您对文件进行了更改,而Git在切换分支时也需要更改这些更改,它就不会允许您更改。要放弃工作中的更改,请使用:

git reset --hard HEAD

然后,您将能够切换分支。