使用 git pull 更新代码,遇到了下面的问题:
error: Your local changes to the following files would be overwritten by merge:
xxx/xxx/xxx.java
Please, commit your changes or stash them before you can merge.
Aborting
解决办法:
1.先备份修改再pull
git stash git pull git stash pop
2.放弃本地修改直接pull
git reset --hard git pull
git stash 命令详解:
git stash: 备份当前的工作区的内容,从最近的一次提交中读取相关内容,让工作区保证和上次提交的内容一致。同时,将当前的工作区内容保存到Git栈中。
git stash pop: 从Git栈中读取最近一次保存的内容,恢复工作区的相关内容。由于可能存在多个Stash的内容,所以用栈来管理,pop会从最近的一个stash中读取内容并恢复。
git stash list: 显示Git栈内的所有备份,可以利用这个列表来决定从那个地方恢复。
git stash clear: 清空Git栈。此时使用gitg等图形化工具会发现,原来stash的哪些节点都消失了。
需求
- 开发的代码还未commit到git本地仓库,就从git远程仓库上pull了代码,导致开发的代码直接被冲掉,需要退回到上一个版本代码。
操作
- 进入到项目git本地仓库文件夹下
- 打开cmd窗口,执行命令:
git reflog
- 找到需要回退的版本,执行命令:
git reset --hard HEAD@{n}
- 如执行:
git reset --hard
61a942c