Git变基

我们在开发中除了初始merge指令合并分支外,我们还可以通过变基来实现分支的合并。

我们通过merge合并分支时,在提交记录中会把所有的分支创建和分支合并的过程全部都显示出来,当项目比较复杂时,我们就要反复创建分支和合并分支,这样会时我们的代码提记录极其混乱,使用变基可以解决这个问题。

一、变基的原理

我们以这么一个图为例,有两条分支,主分支master和分支update,现在演示几变基合并master分支和update分支的原理。

 1. 当我们发起变基时,Git会首先找到两条分支最近的共同节点。

如图所示,master分支和update分支最近的共同节点为C4

 2. 对比当前分支(update分支)相对于共同节点的历史提交,并且将他们提取出来存储到一个临时文件中。

 3. 当前分支(update分支)的指针指向目标分支(master分支)的基底

 4. 以当前基地开始,重新执行临时文件中的操作

二、变基的使用

我们有两个分支,一个是main主分支,一个是update分支,现在进行变基合并操作。

 git rebase [分支名]  # 对当前分支进行变基操作

 

 

在commit代码之后update分支和主分支main就完成了变基,但是这个时候我们的update分支还没有和main分支合并。

合并main分支和update分支

 

 

 变基和merge对于合并分支来说最终结果是一样的,但是变基会使得代码的提交记录更加清晰。

注意,大部分情况下变基和merge时可以互换的,但是如果分支已经提交给远程仓库了,那么这时候尽量不要使用变基。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在VSCode中进行git变基分支的操作可以按照以下步骤进行: 1. 首先,在VSCode中打开终端。可以使用快捷键Ctrl+`或者点击菜单栏的"终端"->"新建终端"来打开终端。 2. 在终端中输入以下命令来查看当前文件下载地址上的所有分支: ``` git branch --all ``` 3. 选择需要切换的分支,使用以下命令进行切换: ``` git checkout origin/develop ``` 4. 执行以下命令来拉取最新的代码: ``` git pull ``` 5. 接下来就可以进行变基操作了。具体的变基操作步骤可以参考引用\[2\]中提到的Git变基方法的使用。 请注意,以上步骤仅供参考,具体操作可能会因项目配置和个人需求而有所不同。建议在进行任何git操作之前,先备份代码或者咨询项目组成员。 #### 引用[.reference_title] - *1* [使用VSCode切换分支下载代码](https://blog.csdn.net/weixin_61088470/article/details/123095344)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Git变基的用法](https://blog.csdn.net/shengzhe8688/article/details/124833051)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [使用vscode创建git新分支](https://blog.csdn.net/cherry_vicent/article/details/127052042)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值