Git pull更新本地冲突和git操作——git pull 撤销误操作,恢复本地代码


使用 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的哪些节点都消失了。

 

git操作——git pull 撤销误操作,恢复本地代码

需求

  • 开发的代码还未commit到git本地仓库,就从git远程仓库上pull了代码,导致开发的代码直接被冲掉,需要退回到上一个版本代码。

操作

  • 进入到项目git本地仓库文件夹下
  • 打开cmd窗口,执行命令:git reflog
  • 找到需要回退的版本,执行命令:git reset --hard HEAD@{n}
  • 如执行:git reset --hard 61a942c
 
 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM