IDEA之Git分支以及Stash使用
访问我的博客
随着公司开发人员的增加,以及多需求的并行开发,功能上线就会碍手碍脚;害怕自己没写完的代码被别人部署到线上,害怕别人代码没写完被自己部署到线上;总之功能上线之前还要和所有开发沟通,能不能部署代码?如果只是几个人的团队倒也无妨,但是开发人员多了,沟通成本就很高了。于是 Git 的分支就发挥它的作用了,本文讲解工作中使用 IDEA 进行分支的管理以及合并,以及其他 Git 使用技巧。
环境准备
为了演示,先用 IDEA 创建一个简单工程,提交到 git 远程仓库当中。
dev-100 分支创建
现在接到了一个编号为 100 的需求,我们在 master 基础上,创建 dev-100 分支
创建新分支 dev-100的同时,并切换到 dev-100 分支。
dev-100 分支代码开发
在 dev-100 分支编写需求编号为 100 的 功能,代码完成后进行 commit
以及 push
(如果这个分支只有你一个人在开发的话,就不用 push
到远程分支了,只需要 commit
即可)
分支合并
现在我们要把 dev-100 分支上的代码合并到 master 主分支上
先切换到 master 分支
合并 dev-100 分支到 master 分支之前,建议先对 master 代码进行 pull 更新操作,然后再执行 Merge into Current
如果没有冲突,dev-100 中的代码就会被合并到 master 分支上了,合并成功后,需要 push
才能推送到远程仓库
取消分支合并
合并完成后,但是由于一些问题,我们想要取消本次合并,右键 git,选择 Reset HEAD
HEAD^ 是还原到上一个版本,HEAD^^ 是还原到上上一个版本。
Reset Type 有三种:
- mixed 默认方式,只保留源码,回退commit和index信息
- soft 回退到某个版本,只回退了commit的信息,不会恢复到index file一级。如果还要提交,直接commit
- hard 彻底回退,本地源码也会变成上一个版本内容
一般使用默认的 mixed 或者粗暴的 hard 方式。
我们这里是取消合并,所以选择 Hard
方式,并且是HEAD^
还原到上一个版本,回退后恢复了原来 master 的代码。
解决合并冲突问题
接下来演示合并冲突,此时是在 master 分支,我们修改文件,并 commit 以及 push 到远程仓库。
此时再把 dev-100 分支合并到 master 分支就会提示冲突。
双击冲突文件,处理冲突。
处理完成后,点击 apply 即可,如果有多个冲突文件,都按照这种方式处理,这是我们处理完冲突之后的代码。
dev-100 分支已经被成功合并到 master 了,就可以删除了。可以直接删除远程 dev-100 分支,删除时 IDEA 会提示是否同时删除本地的 dev-100 分支,勾选即可。
现在我们把分支合并的结果 push 到远程仓库。
代码暂存之git stash
编号 100 的需求完成之后,现在我们又接到一个新的需求,正在 dev-101 分支进行开发,开发还未完成。
突然线上出现 bug,需要我们紧急进行修改,于是我们要基于最新的 master 分支新建一个 bug 分支 bug-12,需要先切换到 master 分支,但是当前分支的代码没有commit, 如果直接切换到 master 分支的话,dev-101 分支上的新增代码就会跑到 master 分支,而代码又不能此时 commit ,于是就轮到 stash 出场了。
Stash 会保存当前工作进度,会把暂存区和工作区的改动保存起来。
添加备注,选择 CREATE STASH。你会发现当前工作区内的代码被恢复成了原样。
代码暂存还原
此刻切换到 master 分支,并创建 bug-12 分支进行修复 bug,修复完成后合并到 master 分支并 push 到远程仓库,上文已经演示如何合并,在此不再赘述。
将 bug-12 与 master 合并完成之后,现在要接着写 dev-101 需求代码,首先先切换到 dev-101 分支;
但是之前的代码已经被我们放到了 git 的 stash 当中,我们现在要把代码还原到工作区当中。
选择 Unstash Changes
选择之前保存的,同时勾选 Pop stash(还原完成后,会自动删除这个 stash),确定后,工作区之前写的代码就又回来了。
结语
Stash 利用好了,就可以自如切换分支,面对突如其来的需求也不必烦恼了~
转载于:https://www.cnblogs.com/vcmq/p/10162041.html
IDEA之Git分支以及Stash使用相关推荐
- 如何获取所有Git分支
我克隆了一个Git存储库,它包含大约五个分支. 但是,当我做git branch我只看到其中一个: $ git branch * master 我知道我可以做git branch -a来查看所有分支, ...
- git分支/标签操作
git分支类似于某一个模块,等到所有模块开发完毕时,最后聚合在一起形成一个项目.而分支之间一般是不会受影响的. git 分支的基本操作: git branch branchname 表示创建分支,新建 ...
- 【转】玩转git分支
玩转git分支 https://www.cnblogs.com/sunshine-anycall/p/4342520.html 搞个代码的管理工具,居然不弄上分支啥的东西.这简直太low了.尤其是在使 ...
- git如何切换分支_拜托,不要再问我Git分支如何使用
今天来讲讲我使用Git分支的一些经验,记录一下,希望对大家有帮助. 阐述 在平常开发中,一般都会对应三种环境,本地环境.测试环境.线上环境.开发的基本流程都是先在本地环境开发好,再把代码发布到测试环境 ...
- 使用当前更改创建Git分支
我开始在我的主分支上工作,认为我的任务很简单. 过了一会儿,我意识到这将需要更多的工作,我想在一个新的分支中完成所有这些工作. 如何创建一个新分支并随身携带所有这些更改而不会弄脏主人 ? #1楼 如果 ...
- Git分支的作用与使用
目录 一.分支 二.标签.版本 三.分支相关命令及使用 四.Git给分支打标签 五.内容补充 1.git stash 应用场景 2.场景应用"分支的新建与合并" 一.分支 先了解一 ...
- Git进阶(五):git 分支管理策略
文章目录 一.企业级项目分支策略 1.1 主分支 master 1.2 开发分支 develop 1.3 功能分支 feature 1.4 预发布分支 release 1.5 bug 分支 fixbu ...
- Git 命令之stash
Git 命令之stash 前言 1 stash 1.1 描述 1.2 应用场景 命令使用 前言 使用 Git 作为代码版本管理,早已是现在开发工程师必备的技能.可大多数工程师还是只会最基本的保存.拉取 ...
- Git学习(了解版本控制、Git安装配置、Git基本理论、Git搭建、Git文件操作、使用码云或Github、IDEA集成Git,Git分支开发)
学习git之前,我们需要先明白一个概念,版本控制! 版本控制 什么是版本控制 版本迭代,新的版本!版本管理器. 版本控制(Revision Control)是一种在开发的过程中用于管理我们对文件.目录 ...
最新文章
- 【Groovy】集合遍历 ( 操作符重载 | 集合中的 “ << “ 操作符重载 | 使用集合中的 “ << “ 操作符添加一个元素 | 使用集合中的 “ << “ 操作符添加一个集合 )
- 服务器上次文件命令,服务器上次文件命令
- OpenShift Security (5) - 评估部署中的风险
- style 里引用php变量,在VUE style中使用data中的变量的方法详解
- 鸟哥Linux服务器-8
- Servlet容器:Jetty和tomcat的比较
- 钢构件建筑材料英国UKCA认证—EN 13381-8
- 【QT】QCustomPlot图表控件
- Sql代码美化工具:Sql Pretty Printer for SSMS V3.6.1
- Java实现文本加密
- 【寒江雪】Go实现工厂模式
- Wing Pro 7中文版
- 拼多多模式,砍价免费拿商品算法
- H.265之三 -帧内预测(3)
- html崩溃手机代码15,这12行代码分分钟让你电脑崩溃手机重启
- 微信朋友圈里,微信群里的早报新闻简报都是哪里来的呢?
- html图片上的灯光,CSS3 实现灯光照射显示文字动画
- MATALAB绘制色图变换和Voronoi图
- depth是什么意思啊(depth是什么意思啊英语)
- python变量保存为.mat文件
热门文章
- 抽象类和接口到底是什么“垃圾“——教你分类
- linux中$@,$*,$0,$$,$?参数的含义
- QT最常用的字符串操作
- CSRF(跨站请求伪造)攻击 --
- 11 旋转数组的最小数字
- 短信开发系列(二):GSM手机短信开发之短信解码
- python3怎么安装opencv_Python:即使安装了opencv,也无法导入cv2(如何为python3安装opencv3)...
- java自动封箱_java自动封箱是什么意思
- python安装与配置虚拟环境包_python 虚拟环境配置及pypi包使用及包怎么
- 985计算机只考数据结构,初试只考数据结构的985院校