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.经理在本地打标签

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

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

 git push origin 标签名
 例:
 git push origin v1.0

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

  # 删除本地标签
  git tag -d 标签名
  # 删除远程仓库标签
  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

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

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


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

  • 14
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
多人合作中,使用Git来提交代码是一个非常常见的做法。首先,每位开发人员需要克隆远程仓库到本地,并创建自己的分支用于开发新功能或修复bug。当开发人员完成自己的工作后,需要将代码提交到本地仓库,并将修改推送到远程仓库。以下是一个常见的Git多人合作代码提交的流程: 1. 首先,每个开发人员需要从远程仓库克隆代码到本地: ``` git clone <远程仓库地址> ``` 2. 在本地仓库中创建自己的分支,并切换到该分支: ``` git checkout -b <分支名称> ``` 3. 在该分支上进行开发工作,并定期提交自己的代码: ``` git add . git commit -m '描述本次提交的内容' ``` 4. 当开发人员完成自己的工作后,需要将修改推送到远程仓库: ``` git push origin <分支名称> ``` 5. 当其他开发人员也完成了自己的工作并将代码推送到远程仓库后,可以使用以下命令将远程仓库中的最新代码合并到本地仓库: ``` git pull origin <分支名称> ``` 请注意,如果在合并过程中出现冲突,需要解决冲突后再次提交代码。 以上是一个基本的Git多人合作代码提交的流程。每个开发人员都可以在自己的分支上进行开发,并将代码提交到远程仓库,以便其他开发人员可以获取并合并最新的代码。这样可以有效地协作开发,并保持代码的版本控制和一致性。<span class="em">1</span><span class="em">2</span><span class="em">3</span>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

learning-striving

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值