搜索
首页开发工具gitGIT 的分支与合并

GIT 的分支与合并

Jul 22, 2020 pm 05:55 PM
git分支合并

GIT 的分支与合并

如何将两个分支合并到一起。就是说我们新建一个分支,在其上开发某个新功能,开发完成后再合并回主线。

1.   git merge

咱们先来看一下第一种方法 —— git merge

在 Git 中合并两个分支时会产生一个特殊的提交记录,它有两个父节点。翻译成自然语言相当于:“我要把这两个父节点本身及它们所有的祖先都包含进来。”下面具体解释。

# 创建新分支 bugFix
git branch bugFix

# 切换到该分支
git checkout bugFix

# 提交一次
git commit

#   切换回 master
git checkout master

#  再提交一次
git commit

# 用 git merge 把 bugFix 合并到 master
git merge bugFix

(master 的分支被混入到所有的提交记录,但 bugFix 没有,所以要进行下面的操作)

# 再把 master 分支合并到 bugFix(因为 master 继承自 bugFix,Git什么都不用做,只是简单地把 bugFix 移动到 master所指向的那个提交记录。)
git checkout bugFix;
git merge master

2.  git rebase

第二种合并分支的方法是 git rebase。rebase 实际上就是取出一系列的提交记录,“复制”它们,然后在另外一个地方逐个的放下去。

Rebase 的优势就是可以创造更线性的提交历史,这听上去有些难以理解。如果只允许使用 Rebase 的话,代码库的提交历史将会变得异常清晰。

# 创建新分支 bugFix分支
git branch bugFix

#提交一次(提交在master分支上)
git commit

# 切换到bugFix分支
git checkout bugFix

# 提交一次(提交在bugFix分支上)
git commit

#使用git rebase把 bugFix 分支里的工作直接移到 master 分支上(移动以后会使得两个分支的功能看起来像是按顺序开发,但实际上它们是并行开发#的)。
git rebase master

注意:提交记录 C3 依然存在(树上那个半透明的节点),而 C3'是我们 Rebase 到 master 分支上的 C3 的副本。

#切换到master分支上(为了进行更新master的操作)
git checkout master

#把master的 rebase 到 bugFix 分支上(由于 bugFix 继承自 master,所以 git 只是简单的把 master 分支的引用向前移动了一下而已。)
git rebase bugFix

推荐教程:《Git

以上是GIT 的分支与合并的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:jb51。如有侵权,请联系admin@php.cn删除
git和github:探索他们的角色和功能git和github:探索他们的角色和功能May 09, 2025 am 12:25 AM

Git和GitHub在软件开发中的角色和功能是管理代码和协作开发。Git通过commit、branch和merge等功能高效管理代码版本,而GitHub则提供代码托管和协作工具,如PullRequest和Issues,提升团队协作效率。

GitHub:发现,共享和为代码做出贡献GitHub:发现,共享和为代码做出贡献May 08, 2025 am 12:26 AM

GitHub是开发者发现、分享和贡献代码的首选平台。1)通过搜索功能查找特定代码库,如Python项目。2)创建仓库并推送代码分享给全球开发者。3)通过Fork和PullRequest参与开源项目并贡献代码。

将git与github使用:实用指南将git与github使用:实用指南May 07, 2025 am 12:11 AM

Git是一种版本控制系统,GitHub是基于Git的在线平台。使用Git和GitHub进行代码管理和团队协作的步骤包括:1.初始化Git仓库:gitinit。2.添加文件到暂存区:gitadd.。3.提交更改:gitcommit-m"Initialcommit"。4.关联GitHub仓库:gitremoteaddoriginhttps://github.com/username/repository.git。5.推送代码到GitHub:gitpush-uoriginmaste

GitHub的影响:软件开发与协作GitHub的影响:软件开发与协作May 06, 2025 am 12:09 AM

GitHub对软件开发和协作的影响深远:1.它基于Git的分布式版本控制系统,提高了代码安全性和开发灵活性;2.通过PullRequest等功能,提升了团队协作效率和知识共享;3.GitHubActions等工具帮助优化开发流程,提高代码质量。

使用GitHub:共享,管理和为代码做出贡献使用GitHub:共享,管理和为代码做出贡献May 05, 2025 am 12:12 AM

在GitHub上分享、管理和贡献代码的方法包括:1.创建仓库并推送代码,编写README和LICENSE文件;2.使用分支、标签和合并请求管理代码;3.Fork仓库、修改并提交PullRequest贡献代码。通过这些步骤,开发者可以有效利用GitHub提升开发效率和协作能力。

git vs. github:比较分析git vs. github:比较分析May 04, 2025 am 12:07 AM

Git是一个分布式版本控制系统,GitHub是一个基于Git的协作平台。Git用于版本控制和代码管理,GitHub则提供额外的协作功能,如代码审查和项目管理。

git vs. github:了解差异git vs. github:了解差异May 03, 2025 am 12:08 AM

Git是分布式版本控制系统,GitHub是基于Git的在线平台。Git用于版本控制、分支管理和合并,GitHub提供代码托管、协作工具和社交网络功能。

github:前端,git:后端github:前端,git:后端May 02, 2025 am 12:16 AM

Git是后端版本控制系统,GitHub是基于Git的前端协作平台。Git管理代码版本,GitHub提供用户界面和协作工具,两者协同工作提升开发效率。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中