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的组合,用远程仓库代码更新本地仓库的代码,线性合并
相关推荐
qq_12498707537 分钟前
基于Hadoop的信贷风险评估的数据可视化分析与预测系统的设计与实现(源码+论文+部署+安装)
大数据·人工智能·hadoop·分布式·信息可视化·毕业设计·计算机毕业设计
2的n次方_11 分钟前
Runtime 执行提交机制:NPU 硬件队列的管理与任务原子化下发
c语言·开发语言
Hello.Reader12 分钟前
Flink 使用 Amazon S3 读写、Checkpoint、插件选择与性能优化
大数据·flink
2501_9447114328 分钟前
JS 对象遍历全解析
开发语言·前端·javascript
零售ERP菜鸟1 小时前
范式革命:从“信息化”到“数字化”的本质跃迁
大数据·人工智能·职场和发展·创业创新·学习方法·业界资讯
凡人叶枫1 小时前
C++中智能指针详解(Linux实战版)| 彻底解决内存泄漏,新手也能吃透
java·linux·c语言·开发语言·c++·嵌入式开发
Tony Bai1 小时前
再见,丑陋的 container/heap!Go 泛型堆 heap/v2 提案解析
开发语言·后端·golang
Hello.Reader1 小时前
Flink 对接 Google Cloud Storage(GCS)读写、Checkpoint、插件安装与生产配置指南
大数据·flink
JMchen1231 小时前
Android后台服务与网络保活:WorkManager的实战应用
android·java·网络·kotlin·php·android-studio
小糯米6011 小时前
C++顺序表和vector
开发语言·c++·算法