一文说清:git分支基本操作

1 引言

git分支,是git版本管理的一个非常重要的概念。

下面记录一下根据视频学习的相关过程。

没有用到视频中的GitKraken工具,是我看到它要收费,就算了吧,改用免费的SourceTree,可以到git官网下载:

https://git-scm.com/downloads/guis

注:

svn中,有主干(trunk)的概念,跟git的main分支是一个意思。

其实我觉得把main分支改成"主干"的说法,从概念上讲更合适一些。

本文还是沿用主流的说法吧。

2 主分支提交

在main分支创建main1.txt文件,提交一次,如下:

复制代码
echo main1 > main1.txt
git add .
git commit -m "main:1"

用SourceTree工具,可以看到分支结果,如下:

之后依次用上面的方式,创建main2.txt和main3.txt,依次提交两次。

通过SourceTree工具,可以看到分支结果,如下:

表示主分支的3次提交。

3 创建开发分支

使用如下命令,创建dev分支,并切换到dev分支。

复制代码
git branch dev
git switch dev
#或
git checkout dev

可视化结果如下:

命令行显示如下:

表示当前已经切换到dev分支。

注意:

在 Git 2.23 及以后,虽然 git checkout 仍然可以用于切换分支和检出文件,但 Git 官方推荐使用 git switch 来切换分支,使用 git restore 来恢复文件,以使命令的用途更加明确。

4 开发分支提交

创建dev1.txt并提交,如下:

在SourceTree中,点击两次"显示远程分支",就可以看到变化,如下:

5 主分支并行提交

使用如下命令:

复制代码
echo main4 > main4.txt
git add .
git commit -m "main:4"

提交main4和main5两次修改。

可视化分支情况如下:

可以看到main分支和dev分支已经分叉了。

实际工作中,这种情况很常见,因为开发任务都是并行的。

6 合并开发分支

在dev分支确认没有问题后,就要合并到主分支。

首先,切换到主分支。

复制代码
git switch main

再在当前分支(main)下合并目标分支(dev),如下:

复制代码
git merge dev

会提示输入日志,使用默认的即可,默认编辑器使用vim,输入冒号和wq即可,如下:

复制代码
:wq

通过SourceTree,可以清晰地看到合并过程:

在命令行中,可以通过git log命令查看分支图,如下:

复制代码
git log --graph --oneline --decorate --all

结果如下:

相比可视化工具而言,不那么直观,但也够用。

7 删除开发分支

分支合并后,可以删除,命令如下:

复制代码
git branch -d dev

使用branch命令查看,结果如下:

在SourceTree上查看,如下;

可以看到只有main分支了。

一般情况下,如果分支合并了,就要将其删除。分支过多,会导致不好管理。

注意:

如果dev分支未合并,就不能用-d(小写)参数删除该分支,必须用-D(大写)来删除。

8 总结

git分支,可以方便多人并行开发。

git分支常见命令如下(name表示分支名称):

  • 查看分支列表:git branch
  • 创建分支:git branch name
  • 切换分支(推荐):git switch name
  • 切换分支:git checkout name
  • 合并分支:git merge name
  • 删除分支(已合并):git branch -d name
  • 删除分支(未合并):git branch -D name

9 参考

【GeekHour】一小时Git教程"分支简介和基本操作"

视频讲得挺好,感谢作者老杨!

b站确实有不少优秀资源。

相关推荐
趁你还年轻_3 小时前
记录一次git提交失败解决方案
git
关于不上作者榜就原神启动那件事6 小时前
git版本控制学习
git·学习
Cchaofan13 小时前
Git/GitLab日常使用的命令指南来了!
git·gitlab
可乐加.糖19 小时前
项目版本管理和Git分支管理方案
java·git·目标跟踪·gitlab·敏捷流程·源代码管理
wingaso19 小时前
[经验总结]删除gitlab仓库分支报错:错误:无法推送一些引用到“http:”
linux·数据仓库·git
ice___Cpu1 天前
Git - 1( 14000 字详解 )
大数据·git·elasticsearch
范纹杉想快点毕业2 天前
以项目的方式学QT开发(一)——超详细讲解(120000多字详细讲解,涵盖qt大量知识)逐步更新!
c语言·数据结构·c++·git·qt·链表·github
qq_653644462 天前
如何查看打开的 git bash 窗口是否是管理员权限打开
开发语言·windows·git·bash
tonngw2 天前
【Mac 从 0 到 1 保姆级配置教程 12】- 安装配置万能的编辑器 VSCode 以及常用插件
git·vscode·后端·macos·开源·编辑器·github
橄榄熊2 天前
Git 常用命令详解
git