初入职场不会Git?经常被团队成员怼?手把手教你如何使用git

这篇具有很好参考价值的文章主要介绍了初入职场不会Git?经常被团队成员怼?手把手教你如何使用git。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Git分支合并选择

简介: 用Git进行多人协作开发时,必然会合并代码,解决冲突。然而合并代码也是需要点技巧的,如果对一些关键命令没有理解去使用的话,git的版本演进路线就会变得很乱,从而造成了日后维护的一些麻烦。 Git上合并代码有git merge 以及 git rebase 两种方式。

用Git进行多人协作开发时,必然会合并代码,解决冲突。然而合并代码也是需要点技巧的,如果对一些关键命令没有理解去使用的话,git的版本演进路线就会变得很乱,从而造成了日后维护的一些麻烦。

Git上合并代码有git merge 以及 git rebase 两种方式。下面将深入两者的用法以及对两者的适用场景作个总结。

前置知识点
  • Master分支:首先,代码库应该有一个、且仅有一个主分支。所有提供给用户使用的正式版本,都在这个主分支上发布。这个分支被称为Master分支;
  • Develop分支:主分支只用来分布重大版本,日常开发应该在另一条分支上完成。我们把开发用的分支,叫做Develop分支。这个分支可以用来生成代码的最新隔夜版本(nightly)。如果想正式对外发布,就在Master分支上,对Develop分支进行"合并"(merge)。
  • 临时性分支:除了常设分支以外,还有一些临时性分支,用于应对一些特定目的的版本开发。临时性分支主要有三种:
    • 功能(feature)分支:它是为了开发某种特定功能,从Develop分支上面分出来的。开发完成后,要再并入Develop。它的命名,可以采用feature-*的形式。
    • 预发布(release)分支:它是指发布正式版本之前(即合并到Master分支之前),我们可能需要有一个预发布的版本进行测试。预发布分支是从Develop分支上面分出来的,预发布结束以后,必须合并进Develop和Master分支。它的命名,可以采用release-*的形式。
    • 修补bug分支:软件正式发布以后,难免会出现bug。这时就需要创建一个分支,进行bug修补。修补bug分支是从Master分支上面分出来的。修补结束以后,再合并进Master和Develop分支。它的命名,可以采用fixbug-*的形式。

有了以上知识点,我们可以了解一般团队开发都是基于feature分支进行开发,然后把feature分支合并到develop分支的。接着我们模拟如下一个实际开发场景。

场景

现在在develop开发分支上,然后你创建了一个feature分支开发新功能,现在团队中另一个成员在develop分支上添加了新的提交。如下图所示

初入职场不会Git?经常被团队成员怼?手把手教你如何使用git,Java,git

现在,如果develop中新的提交和你的工作是相关的。为了将新的提交并入你的分支,你有两个选择:merge或rebase。

merge
git merge

将develop分支合并到feature分支最简单的办法就是用下面这些命令:

git checkout feature
git merge develop 

或者,你也可以把它们压缩在一行里。(个人还是喜欢上面的写法)

git merge develop feature

feature分支中新的合并提交(merge commit)将两个分支的历史连在了一起。你会得到下面这样的分支结构:

初入职场不会Git?经常被团队成员怼?手把手教你如何使用git,Java,git

Merge好在它是一个安全的操作。现有的分支不会被更改,避免了rebase潜在的缺点(后文会讲)。但是这同样意味着每次合并上游更改时feature分支都会引入一个外来的合并提交。如果master非常活跃的话,这或多或少会污染你的分支历史。

git merge --no-ff

默认情况下,Git执行"快进式合并"(fast-farward merge),会直接将develop分支指向feature分支。如git merge里的图所示。使用–no-ff参数后,会执行正常合并,在develop分支上生成一个新节点。为了保证版本演进的清晰,我们希望采用这种做法。关于合并的更多解释,请参考Benjamin Sandofsky的《Understanding the Git Workflow》。

Git演进图如下图所示。(如有错误欢迎指正)

初入职场不会Git?经常被团队成员怼?手把手教你如何使用git,Java,git

可以看到,使用了git merge --no-ff 命令后的git 演进路线是清晰的,命令概括如下:

git checkout feature
git merge --no-ff develop
git rebase

先提个问题吧,git rebase 和 git reset 有什么区别? 如果不知道的话,可以在回顾一下在什么场景下用git merge以及git rebase的,而git reset则仅仅是在当前的分支(一个分支)的版本切换。

接着来讲git rebase。作为merge的替代选择,你可以像下面这样将feature分支并入master分支:

git checkout feature
git rebase develop

它会把整个feature分支移动到develop分支的后面,有效地把所有develop分支上新的提交并入过来。但是,rebase为原分支上每一个提交创建一个新的提交,重写了项目历史,并且不会带来合并提交。

初入职场不会Git?经常被团队成员怼?手把手教你如何使用git,Java,git

rebase最大的好处是你的项目历史会非常整洁。首先,它不像git merge 那样引入不必要的合并提交。其次,如上图所示,rebase导致最后的项目历史呈现出完美的线性。这让你更容易使用git log来查看项目历史。

不过,这种简单的提交历史会带来两个后果:安全性和可跟踪性。如果你违反了Rebase黄金法则,重写项目历史可能会给你的协作工作流带来灾难性的影响。此外,rebase不会有合并提交中附带的信息——你看不到feature分支中并入了上游的哪些更改。

rebase的黄金法则

当你理解rebase是什么的时候,最重要的就是什么时候 不能 用rebase。git rebase 的黄金法则便是,*绝不要在公共的分支上使用它*。

比如说,如果你在develop分支上,rebase到你的feature分支上会发生什么:

初入职场不会Git?经常被团队成员怼?手把手教你如何使用git,Java,git

这次rebase将develop分支上的所有提交都移到了feature分支后面。问题是它只发生在你的代码仓库中,其他所有的开发者还在原来的develop上工作。因为rebase引起了新的提交,Git会认为你的develop分支和其他人的develop已经分叉了。

同步两个develop分支的唯一办法是把它们merge到一起,导致一个额外的合并提交和两堆包含同样更改的提交。不用说,这会让人非常困惑。

所以重要的再强调一遍,***绝不要在公共的分支上使用它。***在你运行git rebase 之前,一定要问问你自己“有没有别人正在这个分支上工作?”。如果答案是肯定的,重新找到一个无害的方式(如git revert)来提交你的更改。不然的话,你可以随心所欲地重写历史。

总结

如果你想要一个干净的、线性的提交历史,没有不必要的合并提交,你应该使用git rebase 而不是git merge 来并入其他分支上的更改。

另一方面,如果你想要保存项目完整的历史,并且避免重写公共分支上的commit, 你可以使用git merge (--no-ff)。

参考文献:文章来源地址https://www.toymoban.com/news/detail-808039.html

  • Merging vs. Rebasing
  • Git分支管理策略

到了这里,关于初入职场不会Git?经常被团队成员怼?手把手教你如何使用git的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • git安装教程(保姆级手把手详细图文)

    一. 认识Git Git是一个分布式版本控制系统,主要用于项目版本管理,一般使用过程为创建分支,修改代码、合并分支 二. 下载Git安装包 1. 登录Git官网: https://git-scm.com/ (官网看版本号,缺点是下载太慢) 2.淘宝镜像下载: https://registry.npmmirror.com/binary.html?path=git-for-windows/ (找到

    2024年01月17日
    浏览(67)
  • 【Git】手把手教你使用Git将本地文件上传到远程仓库

    最近在学习Git,写篇博客记录一下,如有错误还请指正。 文章内容大致如下:         1.新建本地仓库,并上传本地仓库中的文件到远程仓库         2. 修改远程仓库文件内容,同步更新到本地仓库中 准备:         1. 需要在Gitee注册自己账号         2. 已在电

    2024年02月05日
    浏览(56)
  • 手把手教你用git上传项目到GitHub

    github的官方网址:https://github.com ,如果没有账号,赶紧注册一个。 点击Sign in进入登录界面,输入账号和密码登入github。 创建成功可以看到自己的仓库地址,如此,我的远程免费的仓库就创建了。它还介绍了github仓库的常用指令。这个指令需要在本地安装git客户端。 Git是目

    2024年01月18日
    浏览(52)
  • 毕业季 | 程序员初入职场必备软件开发神器,华为云Astro带你开启新篇章

    摘要: 5分钟写出应用,10分钟开发大屏,新手程序员必学技能之华为云Astro,快来get。 本文分享自华为云社区《毕业季 | 程序员初入职场必备软件开发神器,华为云Astro带你开启新篇章》,作者:华为云社区精选 。 这一届初入IT职场的毕业生有多难? 既要在“最难”就业季

    2024年02月11日
    浏览(54)
  • 2023最新最全git安装教程,保姆级手把手式安装!!!

            目录 一、git简介 二、安装过程       1.首先进入git的官网:https://git-scm.com/然后选择Downloads。       2.接着选择与自己电脑系统对应的下载选项,我的电脑是windows7的系统,因此选择windows。       3.进去之后,先别着急选择,先查看自己的电脑系统是64位操作

    2024年02月05日
    浏览(43)
  • 手把手教会Git分布式系统版本管理工具

    前言 一、Git是什么? 1.1 版本控制器的概念 1.2 Git的强大 1.3 Git的安装 二、Git 基本操作 2.1 创建 Git 本地仓库 2.2 认识⼯作区、暂存区、版本库 2.3 add、commit命令 2.4 Git log命令 2.5 .git文件 index: 暂存区,git add 后会更新该内容。 HEAD: 默认指向 master 分⽀的⼀个指针。 refs/heads/ma

    2024年04月14日
    浏览(55)
  • Git 使用教程:最详细、最正宗手把手教学(万字长文)

    一:Git 二:SVN与Git的的区别 三、安装Git 四:常规操作 五:远程仓库 六:创建与合并分支 七:bug分支 八:多人协作 九:git可视化工具 Git 是一种分布式版本控制系统,用于管理软件项目的源代码。它是由 Linux 之父 Linus Torvalds 开发的,并已经成为了现代软件开发领域中最流

    2024年02月16日
    浏览(51)
  • 配置安装Git,使用Gitee仓库(手把手从无到有)

    首先 Git 是什么? Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 点击下载Git(Windows版本) 1、打开下载链接之后,点击图中箭头所指,即可下载最新版本的 Git 注意:由于是国外网站,下载速度有很大问题,这里提供一个国内镜像下载站

    2024年02月10日
    浏览(66)
  • 基于Git与Tortoisegit的Gitee(码云)手把手入门教学

    📢个人主页:未来秃头仔 📢欢迎点赞👍收藏⭐留言📝如有错误敬请指正! 前言          最近刚好学习完“鹏哥C语言”的gitee的安装,为了更方便快捷的学习使用,自己总结了一下。         此教程手把手教学,能实现Git和Tortoisegit的安装和简单的使用。除此之外,还

    2024年02月04日
    浏览(80)
  • 手把手用Git,上传本地项目到gitee,看这篇就够了

    Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 Gitee是一个代码托管平台,提供了代码托管、版本管理、协作开发、代码审查等功能。像这种平台还有GitHub,GitLab等。 本篇主要介绍如何将本地项目上传到gitee进行代码托管。 请确保git已经安

    2024年02月03日
    浏览(65)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包