当前位置:   article > 正文

git多人协作开发、代码冲突及解决冲突、分支操作_多人开发git避免冲突

多人开发git避免冲突

前接:Git管理源代码、git简介,工作区、暂存区和仓库区,git远程仓库github,创建远程仓库、配置SSH,克隆项目

一、 多人协同开发

1.1 代码编辑界面介绍

1.2 模拟张三先编辑login.py文件代码

  • 进入张三本地仓库:cd E:\downloads\study\FL_code\GitStudy\zhangsan\info
  • 编辑代码:num1 = 10
  • 本地仓库记录版本:git commit -am '第一个变量'
  • 推送到远程仓库:git push

新增代码

遇到的问题:执行git push时弹出以下对话框

解决:connect to github中personal access token生成token方法

执行成功

1.3 模拟经理后编辑login.py文件代码

  • 进入经理本地仓库:cd E:\downloads\study\FL_code\GitStudy\manager\info
  • 经理同步服务器代码:git pull
  • 编辑代码:num2 = 20
  • 本地仓库记录版本:git commit -am '第二个变量'
  • 推送到远程仓库:git push

 ​​​​

1.4 模拟张三同步服务器代码

  • 本次可以把num2同步到张三的本地仓库

1.5 按照以上2-3-4步骤循环操作,即可实现基本的协同开发

1.6 总结

  • 要使用git命令操作仓库,需要进入到仓库内部
  • 要同步服务器代码就执行:git pull
  • 本地仓库记录版本就执行:git commit -am '版本描述'
  • 推送代码到服务器就执行:git push
  • 编辑代码前要先pull,编辑完再commit,最后推送是push

二、代码冲突

  • 提示:多人协同开发时,避免不了会出现代码冲突的情况
  • 原因:多人同时修改了同一个文件
  • 危害:会影响正常的开发进度
  • 注意:一旦出现代码冲突,必须先解决再做后续开发
代码冲突演练

2.1 张三先编辑login.py文件代码

  • 进入张三本地仓库:cd E:\downloads\study\FL_code\GitStudy\zhangsan\info
  • 拉取服务器最新代码:git pull
  • 编辑代码:num3 = 30
  • 本地仓库记录版本:git commit -am '第三个变量'
  • 推送到服务器仓库:git push
  • 张三本地仓库和远程仓库代码如下:

2.2 经理后编辑login.py文件代码

  • 进入经理本地仓库:cd E:\downloads\study\FL_code\GitStudy\manager\info
  • 编辑代码:num3 = 30
  • 本地仓库记录版本:git commit -am '第三个变量'
  • 推送到服务器仓库:git push
  • 以上操作会出现代码冲突

    • 提示需要先pull

  • 冲突代码表现
    • zhangsan的login.py中第五行是num3 = 3,已经提交给服务器
    • manager的login.py中第五行是num3 = 30,第五行在服务器已被占位,所以manager无法推送出去

2.3 解决冲突

  • 原则:谁冲突谁解决,并且一定要协商解决
  • 方案:保留所有代码 或者 保留某一人代码
  • 解决完冲突代码后,依然需要addcommitpush

  • 提示:如果张三执行pull没有影响,就算真正解决了冲突代码

补充:
  • 容易冲突的操作方式

    • 多个人同时操作了同一个文件
    • 一个人一直写不提交
    • 修改之前不更新最新代码
    • 提交之前不更新最新代码
    • 擅自修改同事代码
  • 减少冲突的操作方式

    • 养成良好的操作习惯,先pull在修改,修改完立即commitpush
    • 一定要确保自己正在修改的文件是最新版本的
    • 各自开发各自的模块
    • 如果要修改公共文件,一定要先确认有没有人正在修改
    • 下班前一定要提交代码,上班第一件事拉取最新代码
    • 一定不要擅自修改同事的代码

三、标签

  • 当某一个大版本完成之后,需要打一个标签
  • 作用:

    • 记录大版本
    • 备份大版本代码

      • master分支:v1.0→v2.0→...

模拟经理打标签

1.进入到经理的本地仓库info

 cd E:\downloads\study\FL_code\GitStudy\manager\info

2.经理在本地打标签

  1. git tag -a 标签名 -m '标签描述'
  2. 例:
  3. git tag -a v1.0 -m 'version1.0'

3.经理推送标签到远程仓库

  1. git push origin 标签名
  2. 例:
  3. git push origin v1.0

补充:删除本地和远程标签

  1. # 删除本地标签
  2. git tag -d 标签名
  3. # 删除远程仓库标签
  4. git push origin --delete tag 标签名

 四、分支

  • 作用:
    • 区分生产环境代码以及开发环境代码
    • 研究新的功能或者攻关难题
    • 解决线上bug
  • 特点:
    • 项目开发中公用分支包括master、dev
    • 分支master是默认分支,用于发布,当需要发布时将dev分支合并到master分支
    • 分支dev是用于开发的分支,开发完阶段性的代码后,需要合并到master分支
模拟经理分支操作
  • 对比:操作分支前的代码

4.1进入到经理的本地仓库info  :cd E:\downloads\study\FL_code\GitStudy\manager\info

4.2 查看当前分支:git branch

没有创建其他分支时,只有(master)main分支

4.3 经理创建并切换到dev分支

 git checkout -b dev

4.4 设置本地分支跟踪远程指定分支(将分支推送到远程)

git push -u origin dev

执行前执行后 4.5 经理在dev分支编辑代码

4.6 管理dev分支源代码:addcommitpush

4.7 dev分支合并到master(main)分支

  • 提示:只有当dev分支合并到master分支成功,张三才能获取到num4
  • 7.1 先切换到master分支

      git checkout main

7.2 dev分支合并到master分支

  git merge dev

7.3 经理推送合并分支操作到远程仓库

  • 合并分支默认在本地完成,合并后直接推送即可

    git push

 

8.张三同步经理合并后的num4

  • 只有当张三同步代码成功,分支合并才算成功

    1. cd E:\downloads\study\FL_code\GitStudy\zhangsan\info
    2. git pull


学习导航:http://www.xqnav.top 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/秋刀鱼在做梦/article/detail/915192
推荐阅读
相关标签
  

闽ICP备14008679号