赞
踩
工作区某文件为modified(修改)状态且远程仓库中该文件被人修改过且push推送,就导致了Your local changes to the following files would be overwritten by merge这个错误。
方法一:
我开始是用
git add.和commit去解决,问题是可以解决,但是我们公司同事说,因为我们没有自己的分支,都在master上进行操作。这样用commit会导致新的分叉。所以不推荐使用。
- git add .
- git commit -m 'xxx'
方法二:【推荐】
1、先git stash 把更改存到一个堆栈中(也叫临时工作区,可以有多个),这时页面的修改会消失。
2、再git pull 拉取新代码
3、最后把修改用 git stash apply 或git stash pop 弹出来。这时保存的修改和拉取的新代码会有冲突显示,去解决即可。
- git stash
- git pull
- git stash apply
最后,补充一下git stash。已经pop与apply的区别
git stash命令的作用就是将目前还不想提交的但是已经修改的内容进行保存至堆栈中。
git stash pop 会删除最近保存的内容
将当前stash中的内容弹出,并应用到当前分支对应的工作目录上。 该命令将堆栈中最近保存的内容删除。
git stash apply 不会删掉最近保存的内容
将堆栈中的内容应用到当前目录,不同于git stash pop,该命令不会将内容从堆栈中删除,也就说该命令能够将堆栈的内容多次应用到工作目录中,适应于多个分支的情况。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。