Git->git pull 和 git pull --rebase的详解

Git拉取代码的坑

  • 格式:git xx指令 origin/远程仓库分支名称
  • 假如本地仓库和远程仓库都是空的
    • 本地仓库向远程仓库提交一个文件
      • git commit -a -m "local first commit"-a暂存修改文件到暂存区,准备本地提交。-m表示提交信息
      • git push origin refs/heads/master:将本地master分支的最新本地提交(refs/heads/master)推送到远程仓库origin的同名分支
        在这里插入图片描述
  • 本地仓库分支记录
    在这里插入图片描述
  • 远程仓库分支记录
    在这里插入图片描述

git fetch

从远程仓库获取本地仓库所有尚未拥有的版本更新,只是获取,不会进行远程仓库和本地仓库的代码合并和代码变基,需要手动进行代码合并git merge origin/master代码变基git rebase origin/master`

  • 远程仓库有一笔新的远程提交,本地仓库并没有办法感知
    在这里插入图片描述
  • 本地仓库使用git fetch查看远程仓库最新的代码提交
    • 本地仓库分支记录
      在这里插入图片描述
    • 远程仓库分支记录
      在这里插入图片描述

git merge origin/master

  • 假如本地仓库没有本地提交,本地仓库使用git merge origin/master手动合并刚才git fetch获取到远程仓库的代码更新。此时本地仓库和远程仓库的代码一致
    在这里插入图片描述
    • 本地仓库分支记录
      在这里插入图片描述
    • 远程仓库分支记录
      在这里插入图片描述
  • 假如本地仓库有本地提交,本地仓库使用git merge origin/master手动合并刚才git fetch获取到远程仓库的代码更新,需要在本地仓库解决冲突的代码文件
    • 本地仓库做一些修改并本地提交git commit -a -m "local second commit",但还没有推送到远程仓库
      在这里插入图片描述
    • 远程仓库做一些修改并远程提交
      在这里插入图片描述
    • 本地仓库使用git fetch查看远程仓库最新的代码提交
      • 本地仓库分支记录 在这里插入图片描述
      • 远程仓库分支记录在这里插入图片描述
    • git merge origin/master手动合并刚才git fetch获取到远程仓库的代码更新,需要本地解决冲突
      在这里插入图片描述
    • 冲突解决完成后,提交到本地仓库git commit -a -m "merge local origin commit",再推送到远程仓库git push origin refs/heads/master,本地仓库和远程仓库的代码才会一致,git merge方式会造成代码提交的分叉和合并
    • 本地分支记录
      在这里插入图片描述
    • 远程分支记录
      在这里插入图片描述

git rebase origin/master

  • 假如本地仓库没有本地修改和本地提交,本地仓库使用git rebase origin/master手动变基刚才git fetch获取到远程仓库的代码更新,此时本地仓库和远程仓库的代码一致
  • 远程仓库有一笔新的远程提交,本地仓库并没有办法感知
    在这里插入图片描述
    • 本地分支记录
      在这里插入图片描述
    • 远程分支记录
      在这里插入图片描述
  • 假如本地仓库有本地提交,本地仓库使用git rebase origin/master手动合并刚才git fetch获取到远程仓库的代码更新,需要在本地仓库解决冲突的代码文件
    • 本地仓库做一些修改并本地提交git commit -a -m "local thid commit",但还没有推送到远程仓库
      在这里插入图片描述
    • 远程仓库做一些修改并远程提交
      在这里插入图片描述
    • 本地仓库使用git fetch查看远程仓库最新的代码提交
      • 本地仓库分支记录
        在这里插入图片描述

      • 远程仓库分支记录
        在这里插入图片描述

    • git rebase origin/master手动合并刚才git fetch获取到远程仓库的代码更新,需要本地解决冲突
      在这里插入图片描述
    • 冲突解决完成后,提交到本地仓库的暂存区git add hello.txt,再使用git rebase --continue执行之前被冲突打断的rebase操作,git会自动创建一个线性提交,不会像git merge那样的分叉和合并
      在这里插入图片描述

总结

  • git fetch:从远程仓库获取最新的代码更新,但是不会自动合并或修改你的本地仓库代码
  • git merge:合并两个分支代码,会出现代码提交的分叉和合并,非线性合并
  • git rebase:合并两个分支代码,不会出现代码提交的分叉和合并,线性合并
  • git pullgit fetch + get merge的组合,用远程仓库代码更新本地仓库的代码,非线性合并
  • git pull --rebasegit fetch + get rebase的组合,用远程仓库代码更新本地仓库的代码,线性合并

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/861088.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

常微分方程算法之编程示例五(阿当姆斯法)

目录 一、研究问题 二、C代码 三、计算结果 一、研究问题 本节我们采用阿当姆斯法(Adams法)求解算例。 阿当姆斯法的原理及推导请参考: 常微分方程算法之阿当姆斯法(Adams法)_四步四阶adams显格式;三步四阶adams隐…

10.二次开发——黑马程序员Java最新AI+若依框架项目

目录 前言零、使用若依修改器修改项目名称一、创建sky-merchant模块1.创建模块2. 在新模块中导入依赖3. 父工程锁定版本4. sky-admin 导入依赖 二、菜品管理页面生成1.根据页面原型,确定表信息2.设计表3使用代码生成器生成页面4,下载tb_dish代码并分别导…

Matlab|【免费】含氢气氨气综合能源系统优化调度

目录 主要内容 部分代码 结果一览 下载链接 主要内容 该程序参考《_基于氨储能技术的电转氨耦合风–光–火综合能源系统双层优化调度》模型,对制氨工厂、风力发电、电制氢、燃气轮机、火电机组等主体进行建模分析,以火电机组启停成本、煤耗…

VS Code修改菜单栏字体大小

修改方法 打开VS Code,快捷键 CtrlShiftP,在弹出的输入框中输入 setting,找到带有JSON的一项,如图所示: 原文链接 window.zoomLevel 前后变化 终端字体大小 File -> Preferences -> Settings -> Features…

海外短剧系统:一扇窥探多元文化的奇妙之窗

随着全球化的推进,文化交流的壁垒逐渐消融,我们得以更加便捷地领略到世界各地的独特风情。在这一背景下,海外短剧系统应运而生,它如同一扇扇虚拟的窗户,将我们带入不同国家、不同民族、不同文化的世界,让我…

Spark算法之ALS模型(附Scala代码)

Spark算法之ALS模型(附Scala代码) 在大数据时代,个性化推荐系统已成为连接用户与信息的桥梁,而算法则是构建这一桥梁的基石。Apache Spark,作为一款强大的分布式计算系统,提供了丰富的机器学习库&#xff…

比特币生态系统的现状与流动性提升的新路径

自2009年中本聪发布比特币白皮书以来,比特币一直被誉为“数字黄金”,在加密货币领域占据着不可动摇的地位。其去中心化、稀缺性和安全性,增强了其作为长期价值储存工具的吸引力。 相比之下,以太坊自2015年问世以来,凭…

超低排放标准

据朗观视觉小编了解发现,超低排放标准作为衡量一个行业或企业环保水平的重要指标,越来越受到社会各界的关注。本文将深入探讨超低排放标准的内涵、实施意义以及未来展望。 一、超低排放标准的定义 超低排放标准,是指在特定工业生产过程中&am…

视频共享融合赋能平台LntonCVS统一视频接入平台数字化升级医疗体系

医疗健康事关国计民生,然而,当前我国医疗水平的地区发展不平衡、医疗资源分布不均和医疗信息系统老化等问题,制约了整体服务能力和水平的提升。视频融合云平台作为推动数字医疗的关键工具,在医疗领域的广泛应用和普及,…

Oracle - 数据库打补丁实践

原文:https://www.cnblogs.com/ddzj01/p/12097467.html 一、概述 本文将介绍如何给oracle数据库打最新补丁,数据库版本为11.2.0.4单实例,操作系统为redhat6.5 二、下载相关升级包 1. 登录MOS,查阅(ID 2118136.2),下载…

如何快速把一篇文章或企业介绍变为视频?

随着科技和数字化的不断发展,企业的营销手段也在不断变革。尤其对于产品宣传来说,用生动的视觉语言直观地展示产品特点和优势,能够彰显企业实力,让社会不同层面的人士对企业产生正面、良好的印象,从而建立对该企业的好…

开发技术-Java集合(List)删除元素的几种方式

文章目录 1. 错误的删除2. 正确的方法2.1 倒叙删除2.2 迭代器删除2.3 removeAll() 删除2.4 removeIf() 最简单的删除 3. 总结 1. 错误的删除 在写代码时,想将其中的一个元素删除,就遍历了 list ,使用了 remove(),发现效果并不是想…

CircuitBreaker断路器-Resilience4j

目录 背景分布式架构面临的问题:服务雪崩如何解决? CircuitBreakerResilience4jCircuitBreaker 服务熔断服务降级三种状态转换例子参数配置案例demo作业 BulkHead隔离特性SemaphoreBulkhead使用了信号量FixedThreadPoolBulkhead使用了有界队列和固定大小…

Opencv中RotatedRect和ellipse的角度方向

版本:opencv-4.7.0-windows Opencv中,大多数时候,逆时针旋转是正方向,但在RotatedRect和ellipse中,顺时针旋转是正方向。 //RotatedRect的角度参数是顺时针为正方向 RotatedRect(const Point2f& center, const Si…

OpenCV练习(2)图像校正

1、傅里叶变换 霍夫变换 直线 角度 旋转2、边缘检测 霍夫变换 直线角度 旋转3、四点透视 角度 旋转4、检测矩形轮廓 角度 旋转 1.目的 实现类似全能扫面王的图像校正功能 2. 基于轮廓提取和透射变换 基于轮廓提取和透射变换的矫正算法更适用于车牌、身份证、人民…

机器人控制系列教程之动力学建模(1)

简介 机器人动力学是对机器人机构的力和运动之间关系与平衡进行研究的学科。机器人动力学是以机器人运动为基础,研究在运动过程中连杆与连杆之间、连杆与工件之间力或力矩等关系。 分类: 根据研究方向的不同,机器人的动力学分析也分为正、逆…

【Qt之·类QTableWidget】

系列文章目录 文章目录 前言一、常用属性二、成员函数2.1 左上角空白区域 三、实例演示总结 前言 一、常用属性 二、成员函数 方法描述selectRow选中行removeRow移除行insertRow插入行rowCount总行数 2.1 左上角空白区域 QTableCornerButton即不属于列表头,也不…

标准版绑定完手机号页面不跳转问题修复

标准版在不登录的情况下,从商品进去下单的时候跳出来登录并绑定手机号,绑定完手机号页面不跳转问题 修改教程如下: 文件目录:template/uni-app/pages/users/binding_phone/index.vue 加如图内容,然后重新打包

分享一套基于SSM的美食推荐管理系统(源码+文档+部署)

大家好,今天给大家分享一套基于SSM的美食推荐管理系统 开发语言:Java 数据库:MySQL 技术:SpringSpringMvcMyBatis 工具:IDEA/Ecilpse、Navicat、Maven 博主介绍: 一名Java全栈工程师,专注于Jav…

3D Web轻量引擎HOOPS Web Platform赋能AEC行业数字化,高效渲染与多格式支持!

在建筑、工程和施工(AEC)行业,数字化转型和高效协作正变得越来越重要。为应对日益复杂的项目需求和不断提升的质量标准,AEC企业需要一种强大的工具来实现高效的3D可视化和数据管理。HOOPS Web Platform作为一款综合性3D开发平台&a…