当前位置: 首页 > news >正文

IDEA git操作技巧大全,持续更新中

作者简介

目录

1.创建新项目

2.推拉代码

3.状态标识

5.cherry pick

6.revert

7.squash

8.版本回退

9.合并冲突


1.创建新项目

首先我们在GitHub上创建一个新的项目,然后将这个空项目拉到本地,在本地搭建起一个maven项目的骨架再推上去,全流程走一下一个项目从0开始如何托管给git,后文的操作也会基于该项目上来演示。

首先我们在GitHub上创建一个新的仓库:

在IDEA上把项目拉到本地,拉代码的时候需要进行身份验证,输入自己的用户名密码即可:

在拉下来的目录下手动建一个maven项目,按照maven项目的结构新建好项目结构,这里省略去了test文件夹和resource文件夹,各位需要的话也可以自己加上去:

pom.xml示例:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>org.example</groupId><artifactId>IdeaGitDemo</artifactId><version>1.0-SNAPSHOT</version></project>

然后将该项目变成maven项目:

然后将项目push到远端仓库上即可。

2.推拉代码

在IDEA的右上角有git推拉的选项。

3.状态标识

绿色的新加还未commit的,蓝色表示有所改动但还未commit的。

双击想要查看的某一次commit的某一个文件,会弹出当前版本和上一个版本之间的比较面板:

比较面板里支持一些快捷操作:转跳上一处不同、转跳下一处不同,定位到该文件的源文件。

5.cherry pick

当我们想合并某一些提交,而不是合并两个分支的时候,可以用到cherry pick。

举一个使用场景的例子:

当我们有一个主分支main,然后基于main拉出来两条开发分支Dev_A和Dev_B,两个开发团队在这两条分支上各自在开发不同的功能。在开发过程中Dev_A的开发团队发现了main上的一个bug,然后在自己这条开发分支上修复了这个bug。这时候由于两条开发分支都没有完成,不可能直接将Dev_A合并到任何分支上,只能将修复bug的那一次提交合并到各个分支上,这时候就可以用cherry pick。

比如这个时候,Dev_A上有master内容的bug修复,但是后续又有新开发的内容的提交,要是直接将Dev_A分支合并到main上会将未完成测试的不稳定内容合并到main上去,从而扰乱整个main分支。如果将这个bug修复直接合并到其它开发分支上去,会扰乱其它分支正在进行的正常开发。

这时候切到main分支,,然后将修复bug那一次提交,cherry pick到main分支上:

这时候bug修复的那一次提交已经到main分支上来了,将main分支push上去即可:

6.revert

在实际开发中可能会有这样的情况:

某一段代码在某一个时刻被我们重写了,然后过了没多久客户有个需求变动进来了,发现还是基于原来的代码更好做新的需求。这时候就要求我们把这一段代码回退到上个版本。

很明显是不可能用版本号来将整个代码版本回退到某个版本的,因为其它文件并不需要回退,只有当前的一段代码需要回退。这时候就需要用到revert。revert指令可以将某一个文件回退到指定版本:

revert后回退的文件肯定会和当前文件存在冲突,这时候就需要手动合并冲突:

合并完冲突后,IDEA会自动生成一个标准revert的commit message,commit然后推上服务器即可:

7.squash

在实际开发中我们可能经常会遇见这样的情况:

一个文件刚刚修改完,发现没改对或者没改完,于是又继续修改,继续提交,然后提交里面一大串连续的散碎提交,这时候为了不让log看起来很乱,可以考虑合并多个commit:

首先点要合并的提交里面最早那个,选择从此处开始重构基础:

选择该节点向上的所有节点,squash into,除第一项外后面的所有都选择为squash:

(博主在操作这一步的时候忘了截图,盗了其它地方的一张图,做个示例)

start rebasing:

重新输入commit message。

continue rebasing后可以看到多条提交记录合成了一个:

8.版本回退

该块内容有点多,作为一个章节来不太好聊明白,博主会在接下来的几篇文章中单独写一篇该块内容。写好后会持续更新到本文中,以超链接的方式放到此处来,欢迎大家持续关注~

9.合并冲突

该块内容有点多,作为一个章节来不太好聊明白,博主会在接下来的几篇文章中单独写一篇该块内容。写好后会持续更新到本文中,以超链接的方式放到此处来,欢迎大家持续关注~

http://www.lryc.cn/news/180579.html

相关文章:

  • 计算机操作系统 (王道考研)笔记(四)I/O系统
  • 【Java基础】抽象类和接口的使用
  • Golang的性能优化
  • 实现两栏布局的五种方式
  • 博物馆门票预约APP的设计与实现(源码+lw+部署文档+讲解等)
  • 【AI视野·今日Robot 机器人论文速览 第四十四期】Fri, 29 Sep 2023
  • 一维数组和二维数组的使用(char类型)
  • 1.基本概念 进入Java的世界
  • 程序在线报刊第一期
  • k8s 拉取镜像报错 no basic auth credentials
  • Koa处理请求数据
  • 关于浮点数的 fld、fadd、fstp 汇编指令介绍
  • 知识图谱小白入门(1):neo4j的安装与CQL的使用
  • 一个用java的get请求
  • 作为SiteGPT替代品,HelpLook的优势是什么?
  • uni-app:实现页面效果2(canvas绘制,根据页面宽度调整元素位置)
  • 【24种设计模式】责任链模式(Chain of Responsibility Pattern)
  • 微信小程序一对多个页面间传递数据进行通信,事件触发的实现方法
  • 软件测试之Python基础学习
  • 模块化编程+LCD1602调试工具——“51单片机”
  • 【Linux】UDP的服务端 + 客户端
  • 德国自动驾驶卡车公司【Fernride】完成1900万美元A轮融资
  • 实现水平垂直居中的十种方式
  • 头条号热点采集工具-头条号热文采集软件
  • 了解”变分下界“
  • Andriod 简单控件
  • Substructure‑aware subgraph reasoning for inductive relation prediction
  • 古诗词学习鉴赏APP设计与实现(源码+lw+部署文档+讲解等)
  • 深度学习与python theano
  • 【算法优选】双指针专题——贰