重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
今天就跟大家聊聊有关IDEA 中使用Git Stash的方法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
成都创新互联是网站建设技术企业,为成都企业提供专业的网站设计、做网站,网站设计,网站制作,网站改版等技术服务。拥有10余年丰富建站经验和众多成功案例,为您定制适合企业的网站。10余年品质,值得信赖!环境准备
为了演示,先用 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 或者粗暴的 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 利用好了,就可以自如切换分支,面对突如其来的需求也不必烦恼了~
看完上述内容,你们对IDEA 中使用Git Stash的方法有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。