文章目录一览
Git学习-2
git分支的常用指令及操作
1.分支指令
几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作从开发主线上分离开来进行重大的Bug修改、开发新的功能,以免影响开发主线。
1.1查看本地分支
git branch
1.2 创建本地分支
git branch 分支名
1.3 *切换分支(checkout)
git checkout 分支名
我们还可以直接切换到一个不存在的分支(创建并切换)–常用
git checkout -b 分支名
1.4 *合并分支(merge)
一个分支上的提交可以合并到另一个分支–前提得切换到目标分支
git merge 分支名称
1.5 删除分支
不能删除当前分支,只能删除其他分支
git branch -d b1 删除分支时,需要做各种检查
git branch -D b1 不做任何检查,强制删
使用场景:
比如a、b两个分支,a分支里面的操作b都有,并且b多了一个修改的操作,此时切换到a分支并删除b分支的时候就会提示,因为b分支的有a没有的操作,系统认为你是误删,这时就得使用-D的方式。
1.6 解决冲突
当两个分支上对文件的修改可能会存在冲突,例如同时修改了同一个文件的同一行,这时就需要手动解决冲突,解决冲突步骤如下:
- 处理文件中冲突的地方
- 将解决完冲突的文件加入暂存区(add)
- 提交到仓库(commit)
冲突部分的内容处理如下所示:(借鉴)
2.开发中分支使用原则与流程
几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作从开发主线上分离开来进行重大的Bug修改、开发新的功能,以免影响开发主线。
在开发中,一般有如下分支使用原则与流程:
- master (生产) 分支
线上分支,主分支,中小规模项目作为线上运行的应用对应的分支; - develop(开发)分支
是从master创建的分支,一般作为开发部门的主要开发分支,如果没有其他并行开发不同期上线要求,都可以在此版本进行开发,阶段开发完成后,需要是合并到master分支,准备上线。 - feature/xxxx分支
从develop创建的分支,一般是同期并行开发,但不同期上线时创建的分支,分支上的研发任务完成后合并到develop分支。 - hotfix/xxxx分支
从master派生的分支,一般作为线上bug修复使用,修复完成后需要合并到master、test、develop分支。
还有一些其他分支,在此不再详述,例如test分支(用于代码测试)、pre分支(预上线分支)等等
❤3.分支指令的练习
3.1 创建并切换到dev01分支,在dev01分支提交
3.1.1 [master]创建分支dev01
3.1.2 [master]切换到dev01
当后面括号里变成了dev01,说明已经切换过来了。
3.1.3 [dev01]创建文件b.txt
3.1.4 [dev01]将修改加入暂存区并提交到仓库,提交记录内容为:分支上的提交
3.1.5 [dev01]以精简的方式显示提交记录
我这里不精简,是因为没有用别名的方式。
3.2 切换到master分支,将dev01合并到master分支
3.2.1 [dev01]切换到master分支
3.2.2 [master]合并dev01到master分支
3.2.3 [master]以精简的方式显示提交记录
和上一次的查看记录有区别,两个分支都是最新。
3.2.4 [master]查看文件变化(目录下也出现了b.txt)
3.3 删除dev01分支
3.3.1 [master]删除dev01分支
3.3.2 [master]以精简的方式显示提交记录
只剩下master分支,说明dev01分支确实被删掉了。
3.4 命令汇总
########################### 一、创建并切换到dev01分支,在dev01分支提交
# 1.[master]创建分支dev01
git branch dev01
# 2.[master]切换到dev01
git checkout dev01
# 3.[dev01]创建文件b.txt
touch b.txt
# 4.[dev01]将修改加入暂存区并提交到仓库,提交记录内容为:dev分支上的提交
git add . git commit -m 'dev分支上的提交'
# 5.[dev01]以精简的方式显示提交记录
git log --pretty=oneline --all --abbrev-commit --graph
git-log (别名方式)
########################### 二、切换到master分支,将dev01合并到master分支
# 1.[dev01]切换到master分支
git checkout master
# 2.[master]合并dev01到master分支
git merge dev01
# 3.[master]以精简的方式显示提交记录
git log --pretty=oneline --all --abbrev-commit --graph
git-log (别名方式)
# 4.[master]查看文件变化(目录下也出现了file02.txt)
略
########################## 三、删除dev01分支
# 1.[master]删除dev01分支
git branch -d dev01
# 2.[master]以精简的方式显示提交记录
git log --pretty=oneline --all --abbrev-commit --graph
git-log (别名方式)