webstorm的git使用小技巧

2024-05-04 15:48
文章标签 使用 技巧 git webstorm

本文主要是介绍webstorm的git使用小技巧,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、怎么使用stash

开发过程中,我们可能会面临时这种情况:正在A分支上进行功能的开发迭代,这时,同事向你反馈说B分支上有个bug需要紧急修改,如果这个时候你的代码没有暂存或提交至本地仓库,git是不允许切换的,因为未提交文件可能与目标分支文件存在冲突。要想能够顺利切换分支,有两种方法:

1、将A分支上的修改提交至本地仓库,但不提交至远程,等从B分支切回A分支的时候,在进行提交回退,即:git reset HEAD~1,这样A分支上就不存在临时的提交记录

2、利用git stash将A分支上的修改提交至暂存区(git分为工作区、暂存区、本地仓库、远程仓库四个区域),这里着重说下webstorm下如何使用stash功能,过程如下图:

 

这时工作区已经没有被修改的文件了 

当我们在B分支上修改完成,切换到A分支,该如何调取先前的那些被改动过的文件

2、Cherry-Pick和squash怎么用

通常我们开发一个功能可能会有多次commit记录,如果使用简单的merge合并操作,则会把这些commit记录也全部合并到目标分支。如果你不想在合并分支时体现你多次commit记录的话,就需要进行Cherry-Pick和squash

Cherry-Pick:选择指定的提交记录

squash:提交合并

推荐一篇不错的文章:merge squash 和 merge rebase 区别

2.1、切换到master分支

2.2、从master新建一个新分支,命名为temp(最后会提到)

2.3、选择dev分支的提交记录

2.5、选中要合并的提交记录,右击Cherry-Pick,如果有合并冲突,则解决冲突

2.6、操作完成后,提交记录切换至temp分支,可以看到这两次提交记录已经存在了,说明已经合并成功

2.7、接着我们将本地分支切换到master分支,这一步的作用是让master分支与temp进行合并

2.8、合并,点击Modify options下拉选择合并参数 -- squash(多次提交记录合并成一次提交记录)--no-commit(合并完成后由自己填写commit记录),点击merge

2.9、可以看到合并提交的对应的变更文件都已经出现在工作区了,接下来就是按照常规的commit、pull、push过程执行即可以了

2.10、可以看到master分支上的提交记录只有一次

2.11、最后删分支temp

总结:创建临时分支temp的作用起了中间交换的角色,因为Cherry-Pick会直接将提交记录合并到目标分支,所以将要合并提交全部合并到临时分支temp上,再通过squash将临时分支temp的多次提交记录合并,就可以达到只有一次的记录

 3、tag的使用

这里主要说下tag的作用以及遇到的问题。

作用:用于标记一个版本的完整代码。标签应该打在当前分支的最后一次提交上,否则体现在标签上的提交记录是不完整的,打在最后一次提交,该标签会自动将这次提交之前的所有提交记录囊括到这个标签中,但不会囊括之后的提交记录。那么,就有一个问题来了,如果我标记完,但又有新的提交要在当前分支怎么办?

如果标签没有提交到远程,那只需要删除本地的标签,再重新在最后一次提交上打上标签即可。

如果标签已经推送到了远程,需要先删除远程的标签,否则会提交失败!删除命令如下:

git push origin :ref/tags/xxx(标签名称)

参考文章:Git push 报错-Failed with error: dst refspec xxx matches more than one

 webstorm中推送时需要注意勾选push tags:

 远端查看:

 

关于tag以及和branch的不同

 文章链接:Git-命令行-使用 Tag 标记你的代码

这篇关于webstorm的git使用小技巧的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/959554

相关文章

Spring Boot 集成 Quartz并使用Cron 表达式实现定时任务

《SpringBoot集成Quartz并使用Cron表达式实现定时任务》本篇文章介绍了如何在SpringBoot中集成Quartz进行定时任务调度,并通过Cron表达式控制任务... 目录前言1. 添加 Quartz 依赖2. 创建 Quartz 任务3. 配置 Quartz 任务调度4. 启动 Sprin

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

使用Python实现一个优雅的异步定时器

《使用Python实现一个优雅的异步定时器》在Python中实现定时器功能是一个常见需求,尤其是在需要周期性执行任务的场景下,本文给大家介绍了基于asyncio和threading模块,可扩展的异步定... 目录需求背景代码1. 单例事件循环的实现2. 事件循环的运行与关闭3. 定时器核心逻辑4. 启动与停

如何使用Nginx配置将80端口重定向到443端口

《如何使用Nginx配置将80端口重定向到443端口》这篇文章主要为大家详细介绍了如何将Nginx配置为将HTTP(80端口)请求重定向到HTTPS(443端口),文中的示例代码讲解详细,有需要的小伙... 目录1. 创建或编辑Nginx配置文件2. 配置HTTP重定向到HTTPS3. 配置HTTPS服务器

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Qt中QUndoView控件的具体使用

《Qt中QUndoView控件的具体使用》QUndoView是Qt框架中用于可视化显示QUndoStack内容的控件,本文主要介绍了Qt中QUndoView控件的具体使用,具有一定的参考价值,感兴趣的... 目录引言一、QUndoView 的用途二、工作原理三、 如何与 QUnDOStack 配合使用四、自