善用git提高工作效率

本文介绍了如何利用Git在本地创建多个branch来同时处理不同的开发任务,确保任务间互不干扰。当遇到紧急客户问题时,可以快速切换到特定版本进行修复,并通过Git推送代码供同事审查。在修复问题后,再切换回原来的开发环境,继续原功能的开发。这种方法提高了开发效率,确保了项目的顺利进行。
摘要由CSDN通过智能技术生成

一、在一个仓库里同时进行多个不相关的开发任务

场景

正在本地做一个功能的开发,突然收到某个客户report的问题,此时需要切到跟客户同样的软件版本,复制并修复。如何做?

普通做法

git clone一个新的repo,在新的repo里编译,修改,提交code,解决客户问题。从而不影响正在进行的开发。

高效做法

  1. 将正在进行的开发创建一个本地的branch,提交至本地
git branch my-feature1-dev
git checkout my-feature1-dev
git add .
git commit
  1. 签出客户正在用的软件版本
# customer-xxx-release可以是一个git commit ID,也可以是客户branch名称,也可以是一个git tag。总之能对应到客户正在用的软件版本即可。
git checkout customer-xxx-release -b my-customer-xxx
  1. 编译,修改code,修复客户问题

  2. 修改的部分提交至本地

git add .
git commit   # 此时所有修改都提交到了本地my-customer-xxx的上面
  1. Push到gerrit,给同事reivew
# 这里假设customer-xxx-release是remote的客户branch名称
git push HEAD:refs/for/customer-xxx-release
  1. 同事review +2后,merge。

  2. Release patch给客户

  • 制作patch方法1:
git format-patch HEAD^
  • 制作patch方法2:在gerrit页面点击download patch。
  1. 更新confluence page上关于project的信息,尤其是release信息表格。

  2. 返回原来的功能开发的环境,继续原来的工作。

git checkout my-feature1-dev

以上是两个任务同时进行的例子,多个任务同时进行时同理,创建多个branch即可。

重点总结

  • git在clone时,已经把所有branch,所有历史都保存在了本地。想要切到特定版本,无需联网,一键即可完成。
  • git提供了本地branch的机制,使得本地进行多个branch的开发时,互不干扰。

二、<未完待续>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值