有时候由于操作失误,将自己写的代码本来应该提交到自己的远端分支上,结果提交到了他人的远端分支上,此时应该怎么办呢,如何才能将他人的远端分支恢复原样,并将自己写的代码提交到自己的远端分支上呢?
在网上也搜了很多方法,都不全,只好一个一个试试并结合自己理解实验,终于解决了这个问题。
解决方法如下:
1、选择不该提交了代码的分支
git checkout 不该提交了代码的分支
2、将最近一次提交放回暂存区,并取消此次提交
git reset HEAD^1
3、把暂存的文件提交到git的暂存栈
git stash
4、选择应该提交代码的分支
git checkout 应该提交代码的分支
5、将暂存的文件取出来
git stash pop
6、推送到应该提交代码的分支
git push origin [本地分支名]:[应该提交代码的分支名]
7、再选择不该提交了代码的分支
git checkout 不该提交了代码的分支
8、把不该上去的文件回退掉
git push origin [不该提交代码的分支名] -f