3.3.解决多人协作开发过程中的代码冲突问题
1.在多人协作开发的项目中,每次开发之前每个人最好先同步更新一下github上最新的代码,可以减少冲突的概率
git pull
2.产生冲突
目前咱们演示项目git-demo中有两个开发这,第一个人,nodeing666,第二个,nd-00002,github仓库中最新的代码是nd-00002这个人提交的代码,这个时候,如果nodeing666这个人在开发之前并没有拉取github中最新的代码,而是直接去修改index.html这个页面,例如:
<style>
body{
// nodeing666 修改了首页背景色
background-color: red;
}
</style>
代码写完后,nodeing666把本地代码push到github,此时是提交不上去的,效果如下:
data:image/s3,"s3://crabby-images/1621e/1621ef3c687e214fa7b5df81e23562c38e2c0631" alt=""
3.解决冲突
第一步,产生冲突后,我们首先得去把远程仓库(origin/master)中的代码拉取下来,再去查看哪里产生冲突了,执行命令:
git fetch
执行结果:
data:image/s3,"s3://crabby-images/90a8d/90a8d20a1d8cda86e2a33549cf7499c9f85a6ffc" alt=""
第二步,接下来,我们需要去对比本地master分支和远程仓库中的master分支
git diff master origin/master
执行结果:
data:image/s3,"s3://crabby-images/e52dd/e52dde902e9d12023001863dd3b745b2dc63d292" alt=""
第三步,手动把远程master分支和本地master分支合并
git merge origin/master
执行后,index.html页面中变成了这样:
data:image/s3,"s3://crabby-images/02f3d/02f3d658ffc769285ce46e59a5e9fd7d72ba8d09" alt=""
此时,你需要取舍一下,当前冲突的代码到底保留什么,本次案例中,经过讨论,认为背景色保留为红色更好,因此,我们把index.html的代码修改成这样:
data:image/s3,"s3://crabby-images/f587d/f587d84a02d00f9683f63777b62fdc643516c7a3" alt=""
经过上一步手动修改代码,咱们已经解决好了冲突
第四步,重新提交代码并同步到远程仓库
git add index.html
git commit -m '解决背景冲突问题'
git push origin master
执行结果:
data:image/s3,"s3://crabby-images/d48f2/d48f23fe139fa4b73d15252c86a4ae050b790dc1" alt=""
网友评论