使用git pull来更新代码时,有时会遇到以下的问题:
error: Your local changes to the following files would be overwritten by merge
....
Please, commit your changes or stash them before you can merge.Aborting
这个问题原因是其他人修改了某个文件并提交到版本库中去了,而你本地也修改了同一个,这时候你进行拉取就会出现冲突了,解决方法,原则是不要去更改别人已经提交的代码,如果确实要更改(不建议也不需要),请先跟当事人沟通。
方法一:放弃本地修改 (此方法本地修改的代码会被丢弃,不可找回)
git reset --hard git pull
git reset --hard:撤销工作区中所有未提交的修改内容,将暂存区与工作区都回到上一次版本,并删除之前的所有信息提交
方法二:同样是放弃本地修改
使用TortoiseGit(小乌龟),打开冲突文件所在目录,如下:
方法三:使用git stash
git stash git pull git stash pop
git stash:保存当前工作进度,能够将所有未提交的修改(工作区和暂存区)保存至堆栈中,用于后续恢复当前工作目录。也可以用git stash save,作用等同于git stash,区别是可以加一些注释
git pull:这个应该不用说了吧!(把服务器仓库的更新拉到本地仓库中)
git stash pop:可以把你刚才stash到本地栈中的代码pop到本地(也可以用git stash apply,区别:使用apply恢复,stash列表中的信息是会继续保留的,而使用pop恢复,会将stash列表中的信息进行删除。)
git stash list:存储到本地栈顶以后,你可以使用git stash list 查看你本地存储的stash日志
git stash clear: 清空Git栈,原来stash的节点都会被清除
本文为崔凯原创文章,转载无需和我联系,但请注明来自冷暖自知一抹茶ckhttp://www.cksite.cn