GIT | 分支
文章目录
创建分支
查看当前本地仓库中有哪些分支
bash
git branch
HEAD所指向的分支就是当前正在工作的分支
bash
cat .git/HEAD
![](https://file.jishuzhan.net/article/1737941579483582465/4c5a472e9ccc554bdd675c71ac840a2d.webp)
创建一个分支
bash
git branch dev
创建好了,但是目前还是指向master
![](https://file.jishuzhan.net/article/1737941579483582465/64ca7a998d4d31360cde13bb1185b401.webp)
用tree命令也可以看到已经创建分支成功了
![](https://file.jishuzhan.net/article/1737941579483582465/cf9c11e4c336849aab3fefa1c612236a.webp)
创建出来的分支,和主分支的最新记录是一样的
![](https://file.jishuzhan.net/article/1737941579483582465/51a3d2aecec138b063b4554c4ce152ee.webp)
切换分支就是让HEAD指向我们的dev分支
bash
git checkout dev
![](https://file.jishuzhan.net/article/1737941579483582465/ddd8dd831e0120b4fbfe3e1f89c9a19c.webp)
我们在dev分支上堆ReadMe文件进行了修改
![](https://file.jishuzhan.net/article/1737941579483582465/a1a5ca2a6a683b381e5e074e40e70b69.webp)
再进行提交
![](https://file.jishuzhan.net/article/1737941579483582465/143c24ac69a6d16a2eedf781f1284079.webp)
这个时候再切换回master分支
查看文件
![](https://file.jishuzhan.net/article/1737941579483582465/778e05c50a440cd0551b7ec383490492.webp)
可以看到刚刚新加的那行文件不见了~~
那我们再切换回dev分支上看
![](https://file.jishuzhan.net/article/1737941579483582465/13f90b3ec3717e65835f93443a39c7ba.webp)
发现那行新加的还在
我们查看这里发现已经变了
我们查看记录
dev上是最新的记录,master分支第二
![](https://file.jishuzhan.net/article/1737941579483582465/fba575e40e31e8ea9fbe25cfa8edbb05.webp)
我们最终的效果是在master分支上看到我们的效果,我们怎么操作呢?
合并分支
这就要我们合并分支,在合并分支之前就需要先切换到我们master分支上
bash
git merge dev
![](https://file.jishuzhan.net/article/1737941579483582465/139d1f152d259f8f1e21e66f5d80945a.webp)
删除分支
只能在其他的分支上删除本分支
bash
git branch -d dev
![](https://file.jishuzhan.net/article/1737941579483582465/298f1ca745868e3655ea0c4219d9908f.webp)
合并冲突
在合并分支的时候,我们在master分支上已经修改了文件,而我在dev分支上也修改了文件,然后合并的时候就会出现报错,我们来演示一下
快速创建分支并且进入分支
bash
git checkout -b dev1
![](https://file.jishuzhan.net/article/1737941579483582465/4d30a704e2bfda3262da764fddaa85b4.webp)
我们将原来的aaa改成了bbb
![](https://file.jishuzhan.net/article/1737941579483582465/b172a32fa49ae1c660fc1b62f634a901.webp)
然后提交上去
![](https://file.jishuzhan.net/article/1737941579483582465/0260fb2b29a569f5f42b09df70e4303e.webp)
我们切换到master分支上查看一下文件内容,发现还是aaa,因为还没有合并
接下来我们就继续将这个aaa改成ccc,然后再进行合并分支
![](https://file.jishuzhan.net/article/1737941579483582465/cb3b81c4e1395ea0cf80cd3cbce8ba09.webp)
![](https://file.jishuzhan.net/article/1737941579483582465/ba63a5dee98c4e9d0bd7a737827e7c58.webp)
这个时候再进行合并,会提示合并冲突
bash
git merge dev1
![](https://file.jishuzhan.net/article/1737941579483582465/29166c78f078c0d44b4ec69514d3856c.webp)
我们打开ReadMe文件查看一下
![](https://file.jishuzhan.net/article/1737941579483582465/0126839b4b74e880e1e9e1fd480dbc2e.webp)
这个时候就要手动选择要保留哪些代码
假设我们就保留这些代码
![](https://file.jishuzhan.net/article/1737941579483582465/5add3f5d45b8e2f8cd16b79cdc69e80e.webp)
然后再进行提交
![](https://file.jishuzhan.net/article/1737941579483582465/cca78d90aa1bb862cf1ca1efc26ba967.webp)
查看是否是最新提交
![](https://file.jishuzhan.net/article/1737941579483582465/5c655ec422748a049d9196855455d376.webp)
可视化的查看方法
bash
git log --graph --abbrev-commit
![](https://file.jishuzhan.net/article/1737941579483582465/f2bfb0d9871932e5162cdf5afd854001.webp)
分支管理策略
不使用Fast forward
模式
创建一个新分支
bash
git checkout -b dev2
![](https://file.jishuzhan.net/article/1737941579483582465/198f4d8e9e020ccedcdc30631dfc585d.webp)
修改ReadMe文件,并提交
![](https://file.jishuzhan.net/article/1737941579483582465/483ff8cf591992fd2bf71958097e2624.webp)
![](https://file.jishuzhan.net/article/1737941579483582465/b05b078153789e920936cb8bea179e42.webp)
切换回master分支后进行合并
不使用Fast forward
模式
bash
git merge --no-ff -m "merge with no-ff" dev2
![](https://file.jishuzhan.net/article/1737941579483582465/6adb4863e4a23b4d494f3e18d5373403.webp)
bug分支
假如我们现在正在 dev2 分支上进行开发,开发到一半,突然发现master 分支上面有 bug,需要
解决。在Git中,每个 bug 都可以通过一个新的临时分支来修复,修复后,合并分支,然后将临时分支删除
![](https://file.jishuzhan.net/article/1737941579483582465/2c9a5203e70fd290414a22490215cce2.webp)
- 这个时候主分支出现了一个bug,这个时候就要i切换到master分支
![](https://file.jishuzhan.net/article/1737941579483582465/14cbf38337fac0c976893206d31be8d1.webp)
那我们不想这样,我们可以这样做
将工作区的内容进行保存
bash
git stash
![](https://file.jishuzhan.net/article/1737941579483582465/d1e43dec9dda2256ebecadea2eaf5e4c.webp)
修复完bug后,我们就需要进行重新回到dev2分支继续开发
bash
git stash pop
![](https://file.jishuzhan.net/article/1737941579483582465/a4db0058225b2a679daa390cba612240.webp)
现在我们到了dev2分支上了,我们继续开发
![](https://file.jishuzhan.net/article/1737941579483582465/54f940e5f345a42aac72d5cc9e6cb1ad.webp)
然后提交,在dev分支上进行了新的提交
![](https://file.jishuzhan.net/article/1737941579483582465/0b2789622daf7f4b1d84f0f9bc39b8d0.webp)
这个时候就需要合并了,但是合并的时候就会出现冲突,刚刚master修改了bug了,这次又要进行合并分支,我们需要解决错误
我们需要不在master上合并分支,在dev合并master主分支,把问题再本地上解决了再做下一步
我们在dev2分支上进行合并
手动修改冲突
然后就可以合并了~~
![](https://file.jishuzhan.net/article/1737941579483582465/eb842db4831d386a95014252273d050f.webp)
最后不要忘了,把刚刚的临时分支和开发分支删除~~
![](https://file.jishuzhan.net/article/1737941579483582465/0a98eceb722859ec97ec9eb4c4d2eb16.webp)
强制删除分支
如果在开发中如果在一个分支上已经开发,对代码进行提交了,这个时候用传统的方法进行删除是不能删除的,我们需要用到-D
来进行删除~~
bash
git branch -D dev3
- 分支在实际中有什么用呢?假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了。如果等代码全部写完再一次提交,又存在丢失每天进度的巨大风险。
- 现在有了分支,就不用怕了。你创建了一个属于你自己的分支,别人看不到,还继续在原来的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的支上,这样,既安全,又不影响别人工作。
- 并且 Git 无论创建、切换和删除分支,Git在1秒钟之内就能完成!无论你的版本库是1个文件还是1万个文件。