git分支的常用指令及操作
几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作从开发主线上分离开来进行重大的Bug修改、开发新的功能,以免影响开发主线。
git branch
git branch 分支名
git checkout 分支名
我们还可以直接切换到一个不存在的分支(创建并切换)–常用
git checkout -b 分支名
一个分支上的提交可以合并到另一个分支–前提得切换到目标分支
git merge 分支名称
不能删除当前分支,只能删除其他分支
git branch -d b1 删除分支时,需要做各种检查
git branch -D b1 不做任何检查,强制删
使用场景:
比如a、b两个分支,a分支里面的操作b都有,并且b多了一个修改的操作,此时切换到a分支并删除b分支的时候就会提示,因为b分支的有a没有的操作,系统认为你是误删,这时就得使用-D的方式。
当两个分支上对文件的修改可能会存在冲突,例如同时修改了同一个文件的同一行,这时就需要手动解决冲突,解决冲突步骤如下:
几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作从开发主线上分离开来进行重大的Bug修改、开发新的功能,以免影响开发主线。
在开发中,一般有如下分支使用原则与流程:
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.1 [dev01]切换到master分支
3.2.2 [master]合并dev01到master分支
3.2.3 [master]以精简的方式显示提交记录
和上一次的查看记录有区别,两个分支都是最新。
3.2.4 [master]查看文件变化(目录下也出现了b.txt)
3.3.1 [master]删除dev01分支
3.3.2 [master]以精简的方式显示提交记录
只剩下master分支,说明dev01分支确实被删掉了。
########################### 一、创建并切换到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 (别名方式)