共同开发时提交代码会遇到代码冲突,第一次遇到就手足无措的我,打算写一篇博客记录下来,下次遇到稳如老狗。
一、远程代码已有更新记录,忘记拉取远程代码,直接提交
单人开发时,我没有先拉远程代码再提交的习惯(千万不要学习,一定要先拉代码再提交),导致我这一次遇到了冲突,不要慌,先找度娘。
找到了些不同的解决办法,最终采用了这种:
git stash //将你的所有修改文件暂存
git pull //拉取远程代码
git stash pop //释放暂存文件
... //然后再去重新暂存提交代码
暂存文件后,git stash pop
只会取回最近一次暂存的文件,如果想要取回某一次暂存的文件,可以用git stash list
查看暂存记录,然后使用git stash apply stash@{2}
,stash@{2}是暂存记录中某一次暂存的标记。
VScode中可以这样操作:
想要释放暂存文件,点击下方的那个图标:
然后apply或者pop都可以,apply不会消除暂存记录,而pop会连记录一起消除掉。
二、更改的代码块发生冲突
如果你发现VScode显示成这个样子,那就是遇到代码块冲突了。
(图片源自该作者:Meltries丶https://blog.csdn.net/qq_42936023)
第一行英文选项从左至右依次为:采用当前更改、采用传入的更改、保留双方的更改、比较变更
=======上面的代码就是当前更改(你自己本地的更改),下面的就是传入的更改(他人提交的更改)。
因为相同的地方有不同改动所以发生冲突了,这时你可以和提交代码的同事沟通要怎样合并代码,然后再点击第一行的英文选项去合并。
合并后就可以正常暂存和提交了。