Git学习笔记4-分支
参考链接廖雪峰git教程:https://www.liaoxuefeng.com/wiki/896043488029600/900388704535136
1.分支创建
创建本地分支:
$ git branch testing #创建一个分支,并命名为testing
创建远程分支(分两步):
$ git branch testing #创建一个分支,并命名为testing
$ git push origin testing #将分支推送到远程(相当于创建一个远程分支)
2.分支切换
$ git switch master #切换到testing分支,即HEAD指向testing分支(在Git2.23及以上的版本中使用)
$ git checkout testing
3.分支创建及切换
$ git switch -c dev #创建dev分支,然后切换到dev分支(在Git2.23及以上的版本中使用)
$ git checkout -b dev
4.合并分支
$ git merge dev #合并指定的dev分支到当前分支
5.删除分支
删除本地分支
$ git branch -d [branch name] #删除分支,git branch --merged结果中的分支可以进行删除
$ git branch -D [branch name] #强制删除分支,git branch --no-merged结果中的分支可以进行强制删除
删除远程分支
$ git push origin :temp #删除远程分支
6.查看
$ git branch #查看所有分支及当前分支
$ git branch -v #查看每一个分支的最后一次提交
$ git branch --merged #查看哪些分支已经合并到了当前分支,结果中的分支可以进行删除
$ git branch --no-merged #查看哪些分支未合并到当前分支,结果中的分支不能删除
7.分支使用流程
$ git switch -c dev #创建并切换到新的分支dev
$ git branch #查看当前的分支,确定结果是dev分支
$ git add readme.txt #修改文件后,在dev分支上暂存文件
$ git commit -m 'branch test' #在dev分支提交文件
$ git switch master #dev分支工作完成,切换回master分支
$ git merge dev #把dev分支的修改合并到当前的master分支,此时master分支文件的内容和dev分支上的内容一样了
$ git branch -d dev #此时可以放心地删除dev分支的了
$ git branch #删除后确认,dev分支不在了
8.遇到冲突时的分支合并流程
$ git switch -c dev #创建并切换到新的分支dev
$ git branch #查看当前的分支,确定结果是dev分支
¥ 修改readme.txt文件
$ git add readme.txt #修改文件后,在dev分支上暂存文件
$ git commit -m 'branch test' #在dev分支提交文件
$ git switch master #dev分支工作完成,切换回master分支
¥ 修改readme.txt文件
$ git add readme.txt #修改文件后,在master分支上暂存文件
$ git commit -m 'master branch test' #在master分支提交文件
$ git merge dev #把dev分支的修改合并到当前的master分支,此时master分支文件的内容和dev分支上的内容一样了
此时,GIt无法执行“快速合并”,必须手动解决冲突后再提交:
$ git status #查看产生冲突的文件:
此时在本地打开产生冲突的文件:
手动删除两个内容中的一个(包括<<<<<<和======标记)
$ git add readme.txt #修改文件后,在master分支上暂存文件
$ git commit -m 'conflict fixedt' #在master分支提交文件
$ git branch -d dev #删除dev分支
工作完成。
9.BUG分支流程
a. 保存现场
$ git stash
b.恢复现场
$ git stash apply stash@{0} #恢复stash@{0}现场
$ git stash drop stash@{0} #删除stash@{0}现场 $ git stash pop stash@{0} #恢复的同时也删除stash@{0}现场
c. bug分支流程
在软件开发中,你正在dev分支中工作。突然接到一个修复代号101bug的任务时,你会很自然的从master分支创建一个分支Bug-101来修复他。但是dev分支上的工作只进行到了一半,还没法提交,此时你可以使用git stash指令存储当前工作现场,等以后恢复现场后在dev分支上继续工作。
当master分支上修复了bug后,因为dev分支是早期从master分支分出来的,所以,这个bug在当前dev分支上也存在。我们可以使用git cherry-pick <commit>把git commit提交所做的修改“复制”到dev分支。
$ git *** #你现在在dev分支上工作
$ git stash #保存现场
$ git switch master #切换到主分支
$ git switch -c Bug-101 #创建Bug-101分支,并切换
¥101Bug 修复工作
$ git add readme.txt
$ git commit -m "fix bug-101" #提交修复的文件,修复工作完成
$ git switch master #切换到主分区
$ git merge --no-ff -m "merge bug fix 101" #合并bug-101分支到master分支
$ git branch -d Bug-101 #删除Bug-101分支
$ git switch dev #切换到修复101bug之前的工作分支
$ git stash list #查看保存的工作现场信息
$ git stash pop #恢复现场,并删除保存的现场内容
在master分支上修复了bug后,我们要想一想,dev分支是早期从master分支分出来的,所以,这个bug其实在当前dev分支上也存在。我们只需要把6560f7c fix bug 101
这个git commit提交所做的修改“复制”到dev分支。
$ git cherry-pick 6560f7c #将master分支指定的git commit提交复制到当前的dev分支
10.分支策略
在实际开发中,我们应该按照几个基本原则进行分支管理:
首先,master
分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;那在哪干活呢?干活都在dev
分支上,也就是说,dev
分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev
分支合并到master
上,在master
分支发布1.0版本;你和你的小伙伴们每个人都在dev
分支上干活,每个人都有自己的分支,时不时地往dev
分支上合并就可以了。所以,团队合作的分支看起来就像这样:
Git学习笔记4-分支的更多相关文章
- git 学习笔记 --Bug分支
软件开发中,bug就像家常便饭一样.有了bug就需要修复,在Git中,由于分支是如此的强大,所以,每个bug都可以通过一个新的临时分支来修复,修复后,合并分支,然后将临时分支删除. 当你接到一个修复一 ...
- git学习笔记09-bug分支-自己的分支改到一半了-要去改bug怎么办?
当你接到一个修复一个代号101的bug的任务时,很自然地,你想创建一个分支issue-101来修复它,但是,等等,当前正在dev上进行的工作还没有提交: 并不是你不想提交,而是工作只进行到一半,还没法 ...
- Git学习笔记五--分支管理
为什么要引入分支? 分支在实际中有什么用呢?假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了.如果等代码全部 ...
- git 学习笔记--Feature分支
软件开发中,总有无穷无尽的新的功能要不断添加进来. 添加一个新功能时,你肯定不希望因为一些实验性质的代码,把主分支搞乱了,所以,每添加一个新功能,最好新建一个feature分支,在上面开发,完成后,合 ...
- GIT学习笔记(4):远程分支
GIT学习笔记(4):远程分支 远程分支 远程分支是什么 远程分支是对远程仓库中的分支的索引.它们是一些无法移动的本地分支:只有在GIT进行网络交互时才会更新.远程分支就是书签,提醒着你上次连接远程仓 ...
- GIT学习笔记(3):分支管理
GIT学习笔记(3):分支管理 何谓分支 GIT是如何存储数据的 GIT不是存储文件差异或者变化量,而是一系列文件的快照.在Git提交时,会保存一个提交(commit)对象,该对象包含一个指向暂存内容 ...
- Git学习笔记与IntelliJ IDEA整合
Git学习笔记与IntelliJ IDEA整合 一.Git学习笔记(基于Github) 1.安装和配置Git 下载地址:http://git-scm.com/downloads Git简要使用说明:h ...
- Git学习笔记(10)——搭建Git服务器
本文主要记录了Git服务器的搭建,以及一些其他的配置,和最后的小总结. Git远程仓库服务器 其实远程仓库和本地仓库没啥不同,远程仓库只是每天24小时开机为大家服务,所以叫做服务器.我们完全可以把自己 ...
- git 学习笔记6--remote & log
git 学习笔记6--remote & log 创建SSH Keys ssh-keygen -t rsa -C "1050244110@qq.com" 本地关联远程 git ...
- 【转帖】Git学习笔记 记录一下
本文内容参考了廖雪峰老师的博文,并做了适当整理,方便大家查阅. 原帖地址 https://wangfanggang.com/Git/git/ 常用命令 仓库初始化 - git init 1 git i ...
随机推荐
- 【bzoj3601】一个人的数论(莫比乌斯反演+拉格朗日插值)
传送门 题意: 求\[ \sum_{i=1}^{n}i^d[gcd(i,n)=1] \] 思路: 我们对上面的式子进行变换,有: \[ \begin{aligned} &\sum_{i=1}^ ...
- 如何将list集合转成String对象
使用Stringutils中的join方法: 方法一: public String listToString(List list, char separator) { return org.apach ...
- 201271050130-滕江南-《面向对象程序设计(java)》第十五周学习总结
201271050130-滕江南-<面向对象程序设计(java)>第十五周学习总结 博文正文开头格式:(2分) 项目 内容 这个作业属于哪个课程 https://www.cnblogs.c ...
- 【树状数组】2019徐州网络赛 query
(2)首先成倍数对的数量是nlogn级别的,考虑每一对[xL,xR](下标的位置,xL < xR)会对那些询问做出贡献,如果qL <= xL && qR >= xR, ...
- Leetcode146-lru-cache
Leetcode146-lru-cache int capacity; int size; Map<Integer, ListNode> map = new HashMap<Inte ...
- Java Metrics工具介绍
目录 简介 快速入门 Maven配置 MetricRegistry Gauge Meter Counter Histgram Timer Reporter 更多用法 参考资料 简介 Metric是一个 ...
- C++ 静态库与动态库以及在 Windows上 的创建、使用
一.什么是库 库是写好的现有的,成熟的,可以复用的代码.现实中每个程序都要依赖很多基础的底层库,不可能每个人的代码都从零开始,因此库的存在意义非同寻常. 本质上来说库是一种可执行代码的二进制形式,可以 ...
- SQL Server in Docker - 还原数据库
SQL Server in Docker 还原数据库 上一会演示了如果在Docker环境下安装SQL Server,这次我们来演示下如何还原一个数据库备份文件到数据库实例上. 使用winscp上传ba ...
- Clickhouse单机部署以及从mysql增量同步数据
背景: 随着数据量的上升,OLAP一直是被讨论的话题,虽然druid,kylin能够解决OLAP问题,但是druid,kylin也是需要和hadoop全家桶一起用的,异常的笨重,再说我也搞不定,那只能 ...
- Docker安装redis的使用
1.Docker安装redis的使用. docker search redis检索redis的服务.先检索再拉取. 2.这里我们拉取官方的镜像,标签为5.0.5.[root@slaver4 ~]# d ...