git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支

简介: git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支

创建分支

查看当前本地仓库中有哪些分支

git branch

HEAD所指向的分支就是当前正在工作的分支

cat .git/HEAD

创建一个分支

git branch dev

创建好了,但是目前还是指向master

用tree命令也可以看到已经创建分支成功了

创建出来的分支,和主分支的最新记录是一样的

切换分支就是让HEAD指向我们的dev分支

git checkout dev

我们在dev分支上堆ReadMe文件进行了修改

再进行提交

这个时候再切换回master分支

查看文件

可以看到刚刚新加的那行文件不见了~~

那我们再切换回dev分支上看

发现那行新加的还在

我们查看这里发现已经变了

我们查看记录

dev上是最新的记录,master分支第二

我们最终的效果是在master分支上看到我们的效果,我们怎么操作呢?

合并分支

这就要我们合并分支,在合并分支之前就需要先切换到我们master分支上

git merge dev

删除分支

只能在其他的分支上删除本分支

git branch -d dev

合并冲突

在合并分支的时候,我们在master分支上已经修改了文件,而我在dev分支上也修改了文件,然后合并的时候就会出现报错,我们来演示一下

快速创建分支并且进入分支

git checkout -b dev1

我们将原来的aaa改成了bbb

然后提交上去

我们切换到master分支上查看一下文件内容,发现还是aaa,因为还没有合并

接下来我们就继续将这个aaa改成ccc,然后再进行合并分支

这个时候再进行合并,会提示合并冲突

git merge dev1

我们打开ReadMe文件查看一下

这个时候就要手动选择要保留哪些代码

假设我们就保留这些代码

然后再进行提交

查看是否是最新提交

可视化的查看方法

git log --graph --abbrev-commit

分支管理策略

不使用Fast forward模式

创建一个新分支

git checkout -b dev2

修改ReadMe文件,并提交

切换回master分支后进行合并

不使用Fast forward模式

git merge --no-ff -m "merge with no-ff" dev2

bug分支

假如我们现在正在 dev2 分支上进行开发,开发到一半,突然发现master 分支上面有 bug,需要

解决。在Git中,每个 bug 都可以通过一个新的临时分支来修复,修复后,合并分支,然后将临时分支删除

  • 这个时候主分支出现了一个bug,这个时候就要i切换到master分支

那我们不想这样,我们可以这样做

将工作区的内容进行保存

git stash

修复完bug后,我们就需要进行重新回到dev2分支继续开发

git stash pop

现在我们到了dev2分支上了,我们继续开发

然后提交,在dev分支上进行了新的提交

这个时候就需要合并了,但是合并的时候就会出现冲突,刚刚master修改了bug了,这次又要进行合并分支,我们需要解决错误

我们需要不在master上合并分支,在dev合并master主分支,把问题再本地上解决了再做下一步

我们在dev2分支上进行合并

手动修改冲突

然后就可以合并了~~

最后不要忘了,把刚刚的临时分支和开发分支删除~~

强制删除分支

如果在开发中如果在一个分支上已经开发,对代码进行提交了,这个时候用传统的方法进行删除是不能删除的,我们需要用到-D来进行删除~~

git branch -D dev3

分支在实际中有什么用呢?假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了。如果等代码全部写完再一次提交,又存在丢失每天进度的巨大风险。

现在有了分支,就不用怕了。你创建了一个属于你自己的分支,别人看不到,还继续在原来的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的支上,这样,既安全,又不影响别人工作。

并且 Git 无论创建、切换和删除分支,Git在1秒钟之内就能完成!无论你的版本库是1个文件还是1万个文件。


相关文章
|
2天前
|
API 开发工具 git
《Git 简易速速上手小册》第3章:分支管理(2024 最新版)
《Git 简易速速上手小册》第3章:分支管理(2024 最新版)
44 1
|
20小时前
|
JSON 开发工具 git
git rebase 合并当前分支的多个commit记录
git rebase 合并当前分支的多个commit记录
|
2天前
|
开发工具 git
git 如何删除本地和远程分支
git 如何删除本地和远程分支
12 0
|
2天前
|
Shell 开发工具 git
git获取gitee老版本的分支内容
git获取gitee老版本的分支内容
|
2天前
|
jenkins 持续交付 开发工具
Git高级使用技巧与策略
【4月更文挑战第30天】本文介绍了Git的高级使用技巧和策略,包括设置命令别名、使用`.gitignore`、交互式暂存、重新排序提交、变基和子模块。此外,还探讨了特性分支、主题分支等分支管理策略,强调保持历史整洁、原子提交以及应对紧急修复的方法。推荐使用GUI工具、钩子和持续集成工具提升效率。掌握这些技巧能有效提升代码管理和团队协作效率。
|
2天前
|
开发工具 git 开发者
【专栏】探讨了 Git 中的 `git rebase` 操作,它用于重新应用提交到另一分支,改变历史顺序
【4月更文挑战第29天】本文探讨了 Git 中的 `git rebase` 操作,它用于重新应用提交到另一分支,改变历史顺序。与 `git merge` 不同,rebase 重写提交历史,提供简洁线性的历史记录。文章介绍了 rebase 的基本操作、应用场景,如整理提交历史、解决冲突和整合分支,并强调了使用注意事项,如避免在公共分支上操作。尽管 rebase 可以带来整洁的历史和冲突解决便利,但其潜在的风险和可能导致的历史混乱需谨慎对待。理解并恰当使用 `git rebase` 可以提升开发效率和代码质量。
|
2天前
|
机器人 Java 测试技术
云效产品使用常见问题之流水线git自定义某一个分支提交节点失败如何解决
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
2天前
|
开发工具 git
git 拉取代码仓库代码报错(合并错误 refusing to merge unrelated histories)
git 拉取代码仓库代码报错(合并错误 refusing to merge unrelated histories)
26 0
|
2天前
|
开发工具 git
git如何创建新分支,GitHub默认分支是main怎么连上
git如何创建新分支,GitHub默认分支是main怎么连上
20 0
|
2天前
|
开发工具 git
对于github不同的分支main或者master,git拉取代码的时候怎么拉取不同分支的代码
对于github不同的分支main或者master,git拉取代码的时候怎么拉取不同分支的代码
24 1

相关实验场景

更多