Idea下面git的使用:变基、合并、优选、还原提交、重置、回滚、补丁

多分支和分支切换

变基和合并

变基是把本项目的所有提交都列出来按顺序一个个提交到目标分支上去

而合并是把两个分支合并起来,但是旧的分支还是可以启动其他分支,在旧的分支上继续开发

matlab 复制代码
master:  A -- B -- C -- M
                      /
feature:       D -- E
matlab 复制代码
master:  A -- B -- C
                   \
feature:             D' -- E'

:::success

主动变基和被动变基的区别

:::

没有什么区别变基,只是把合并的一种策略,把两个分支的有差异的提交,单次一次一次的提交到主动要求变基的分支,比如main分支要求变基到feature,意味着把feature所有和main有差异的提交都提交到main,包括时间顺序。

还原提交是什么

假设之前有个提交出现了bug,就可以使用还原提交查看出bug的节点修改了什么然后把bug之前的节点和bug之后所有节点和bug本次提交。具体如下:

把当前分支重置到此处和回滚操作的区别

分支重置

把当前分支重置到此处相当于把此处之后的所有分支都切除了,但是idea提供多个切除方案:

软重置会把提交历史提交信息都删除,但是数据还是保留。硬重置会把提交历史信息和数据都删除,就好像当时节点提交时候的数据。使用idea进行操作的时候只需要注意是否要软重置和硬重置,混合和保留模式并不是很好的体现在idea上面(因为涉及到暂存区,这个东西被Idea屏蔽了)

代码回滚

你在某个节点上编写了很多代码,你想把编写的代码全部去除还原到最新版本,那么就可以使用回滚

优选操作是什么

就是从某个分支中的提交中获取一个你想要的提交作为一次新提交提交上去,比如说正式版本去测试版本中找到权限控制代码的提交,把权限控制提交作为本节点的新提交,提交到本地,解决好冲突之后,正式版本就可以得到权限控制的代码了,这样做的好处就是测试版本提交了权限控制,但是之后又提交了几个测试功能,但是这几个测试功能的效果并不是很好,正式版本不打算使用只使用权限控制,那么就可以使用cherry pick。

点击收藏夹就可以得到全部分支的提交,选择一个提交到作为新提交,提交上去即可。

创建补丁是什么

补丁在代码开发中的使用确实相对较少。在现代的团队协作和版本控制工具中,如Git,开发人员通常使用分支、合并和拉取请求等功能来管理并发修改和解决冲突。

然而,补丁仍然在某些特定情况下有其用武之地,尤其是在没有直接访问对方代码库或版本控制系统的情况下,或者在需要将更改应用到非版本控制的环境中时。

以下是一些可能使用补丁的场景:

  1. 开源项目贡献:当你想要向一个开源项目提交代码贡献时,但你没有直接的访问权限或合并请求的权限,你可以创建一个补丁文件,并将其提交给项目维护者。项目维护者可以选择接受并应用你的补丁。
  2. 跨版本应用更改:当你需要将某个版本的代码更改应用到另一个版本时,但这两个版本的代码库无法直接合并或比较。在这种情况下,你可以生成一个补丁文件,并将其应用到目标版本中。
  3. 部署到非版本控制的环境:如果你需要将代码更改应用到没有版本控制的环境(如生产服务器)中,你可以使用补丁文件来记录和应用更改,而不是直接复制整个代码库。

尽管补丁的使用相对较少,但它仍然是一种有用的工具,可以在特定情况下帮助解决代码冲突或将更改应用到不同的环境中。在实际开发中,具体使用补丁的需求会因情况而异。

相关推荐
Kiri霧1 小时前
Git入门
git
岁忧1 小时前
(nice!!!)(LeetCode 每日一题) 679. 24 点游戏 (深度优先搜索)
java·c++·leetcode·游戏·go·深度优先
Nejosi_念旧2 小时前
git报错解决:ssh: connect to host github.com port 22: Connection refused
git·ssh·github
你的人类朋友3 小时前
说说git的变基
前端·git·后端
程序设计实验室3 小时前
在Windows上将git与ssh-agent搭配使用,再也不用输入git密码了
windows·git
Clownseven4 小时前
Gitea Webhook教程:实现git push后自动部署更新网站 (CI/CD入门)
git·ci/cd·gitea
猿究院--王升4 小时前
jvm三色标记
java·jvm·算法
妮妮学代码5 小时前
c#:TCP服务端管理类
java·tcp/ip·c#
兔老大RabbitMQ5 小时前
git pull origin master失败
java·开发语言·git
探索java5 小时前
Netty Channel详解:从原理到实践
java·后端·netty