热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

git分支的创建与合并

在git中提倡使用分支,这就涉及到了分支的创建和合并。在git中我们的每次提交类似于一个链表,按照时间顺序向下排列,大约画了一个图

在git中提倡使用分支,这就涉及到了分支的创建和合并。在git中我们的每次提交类似于一个链表,按照时间顺序向下排列,大约画了一个图,每个小圆圈代表一次提交,在git中有有一个主分支master,我们新建的分支最后都要合并到主分支上。


参考了廖雪峰的文章,这里讲 到了一个head(这里就当作他是一个指针,没有认真探讨过这个问题),用head来确定当前分支,比如在master分支(主分支),head指向了最后一次提交,代表当前是在master分支上完成的操作。同样是上面的图加上一个head指向代表当前正在master分支上操作。


如果在master上操作,我们每次的提交都会导致这条分支在一点一点增长。为了避免每次操作主分支错误的代码提交导致的错误,我们需要再创建一个分支,先在这个新建的分支上提交,最后合并到主分支(master)上。

创建一个test分支,并把当前操作的分支切换到这个新建的test分支上,head指向的是test这条分支


创建test分支、切换到test分支

git branch test
git checkout test
上面的两条语句可以用一句来完成,在checkout后面加上-b就可以

git checkout -b test
可以查看当前分支情况(有哪些分支,当前操作的分支)

git branch 可以看到当前有两条分支,当前指向test分支(绿色前面有*)


接下来就可以对文件进行操作,直接把编辑好的文件复制过来

利用命令把文件添加到暂存区,比如我们添加了一个b.txt文件

git add a.txt
也可以在add后面写上.添加所有文件

git add . 如果发现提交暂存的文件有问题,是可以撤销的,查看做出什么修改,并撤销修改

git status
git reset head <文件名字>
在执行git status时就已经告诉我们撤销应该怎么做


文件加到暂存区之后&#xff0c;我们需要提交

git commit -m "提交说明" 提交b.txt作为测试



注意以上的操作都是在test分支上进行的&#xff0c;这张图准确来说放在这里最合适&#xff0c;因为在test分支上完成了一次提交&#xff0c;上面只是创建一个分支并切换到test上


接下来我们应该把test分支上提交的内容合并到主分支master上&#xff0c;在此之前我们先要切换到主分支上&#xff0c;否则是不能执行合并

git checkout master

切换到master分支上查看文件发现刚刚添加的b.txt文件不存在&#xff0c;因为b.txt是在test分支上添加的。

执行合并命令&#xff0c;合并的是test分支&#xff0c;最后的参数是要合并分支的名字

git merge test 这里在git中查看文件列表可以使用windows中的dir命令&#xff0c;也可以使用linux中的ls命令&#xff0c;网上给出的解释是git for window提供了一个环境&#xff0c;而git正常运行就是要依赖这个环境


这里看图比较容易理解&#xff0c;下面的那条是test分支&#xff0c;上面的是master分支



如果没有删除test分支test分支可以继续向后延伸&#xff0c;也就是可以继续在test分支上提交&#xff0c;每次的合并都是把test分支上的内容合并到master&#xff08;主分支上&#xff09;&#xff0c;如下图&#xff1a;


也可以选择删除test分支&#xff0c;在删除之后还是可以创建名为test的分支

git branch -d test

查看分支&#xff0c;可以看到只剩下master分支





转:https://www.cnblogs.com/duzhentong/p/8576499.html



推荐阅读
  • 初始化初始化本地空版本库,仓库,英文名repositorymkdirtest&&cdtestgitinit克隆项目到本地gitclone远程同 ... [详细]
  • 使用在线工具jsonschema2pojo根据json生成java对象
    本文介绍了使用在线工具jsonschema2pojo根据json生成java对象的方法。通过该工具,用户只需将json字符串复制到输入框中,即可自动将其转换成java对象。该工具还能解析列表式的json数据,并将嵌套在内层的对象也解析出来。本文以请求github的api为例,展示了使用该工具的步骤和效果。 ... [详细]
  • Git GitHub多人协作
    在学校做一个小项目需要多人协作,就用到了gitHub,百度了一下多数写得乱七八糟或者支离破碎,于是总结了一下自己的步骤如下,第一次使用GitHUb,哪里不对望大神指出一.前期准备: ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • 如何去除Win7快捷方式的箭头
    本文介绍了如何去除Win7快捷方式的箭头的方法,通过生成一个透明的ico图标并将其命名为Empty.ico,将图标复制到windows目录下,并导入注册表,即可去除箭头。这样做可以改善默认快捷方式的外观,提升桌面整洁度。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • Webmin远程命令执行漏洞复现及防护方法
    本文介绍了Webmin远程命令执行漏洞CVE-2019-15107的漏洞详情和复现方法,同时提供了防护方法。漏洞存在于Webmin的找回密码页面中,攻击者无需权限即可注入命令并执行任意系统命令。文章还提供了相关参考链接和搭建靶场的步骤。此外,还指出了参考链接中的数据包不准确的问题,并解释了漏洞触发的条件。最后,给出了防护方法以避免受到该漏洞的攻击。 ... [详细]
  • Linux磁盘的分区、格式化的观察和操作步骤
    本文介绍了如何观察Linux磁盘的分区状态,使用lsblk命令列出系统上的所有磁盘列表,并解释了列表中各个字段的含义。同时,还介绍了使用parted命令列出磁盘的分区表类型和分区信息的方法。在进行磁盘分区操作时,根据分区表类型选择使用fdisk或gdisk命令,并提供了具体的分区步骤。通过本文,读者可以了解到Linux磁盘分区和格式化的基本知识和操作步骤。 ... [详细]
  • 本文介绍了在使用FIS配置过程中遇到的问题以及解决方法。作者发现在配置roadmap时使用命令行参数出现了诡异现象,uglify了js文件后,html中对js的引用没有被修改。经过多次尝试和验证,联系了FIS开发人员后才得知,使用fis.config.merge会导致一些问题。通过将fis.config.merge改为fis.config.get('roadmap.path').unshift()来添加配置,问题得以解决。文章指出FIS官方文档解释不够详细,提供了解决问题的方法。 ... [详细]
  • 本文详细介绍了git常用命令及其操作方法,包括查看、添加、提交、删除、找回等操作,以及如何重置修改文件、抛弃工作区修改、将工作文件提交到本地暂存区、从版本库中删除文件等。同时还介绍了如何从暂存区恢复到工作文件、恢复最近一次提交过的状态,以及如何合并多个操作等。 ... [详细]
  • 先记住几个专用名词,如下:Workspace:工作区IndexStage:暂存区Repository:仓库区(或本地仓库)Remote:远程仓库一、新建代码库#在当前目录新建一个G ... [详细]
  • 双十一在家学用 Git
    对于所有的开发者来说,掌握一门代码版本控制系统都是必须的,无论是自己做项目,团队合作,工作中的合作,都离不开版 ... [详细]
  • 第一种方法gitarchive-oupdate.zip$(gitdiffnew-versionold-version--name-only)此方法如果文件有删除,则 ... [详细]
  • 前言本篇为大家总结社区多人合作常见的场景和对应的git操作命令。本篇非新手教程,阅读本篇前需具备Git基础知识。Git入门教程请参考https://www ... [详细]
author-avatar
伊甸园的常青藤
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有