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

Git Patch 使用详解:生成、应用与多提交合并导出

在多人协作、代码审查、离线提交或跨仓库迁移的场景中,git patch 是非常实用的技术。本文将系统地介绍如何使用 Git 的补丁机制导出和应用修改内容。


📖 什么是 Git Patch?

严格来说,git patch 并不是一个 Git 命令,而是指 使用 Git 的补丁机制,借助以下命令完成相关操作:

  • git diff
  • git format-patch
  • git apply
  • git am

这些命令共同构成了 Git 补丁工作流。


📦 Git Patch 常用工作流概览

🔹 1. 生成 Patch 文件

✅ 方法 1:仅导出修改内容(不含提交信息)
git diff > my.patch

生成的是基于当前修改与 HEAD 差异的补丁,适合用于分享尚未提交的改动。


✅ 方法 2:导出带有提交历史的补丁(推荐)
# 导出某一次提交
git format-patch -1 <commit-hash># 导出最近 3 次提交
git format-patch -3# 导出当前分支与主分支之间的所有提交
git format-patch origin/main..HEAD

这些命令会生成 .patch 文件,每个提交一个文件,名称格式如:

0001-描述.patch
0002-描述.patch

你可以通过 --output-directory=<目录> 指定生成路径:

git format-patch origin/main --output-directory=./patches

🔹 2. 应用 Patch 文件

✅ 使用 git apply(不记录提交)
git apply my.patch
  • 只会应用内容,不保留原始提交记录。
  • 无法撤销,建议先备份或使用 git apply -R 撤销。

✅ 使用 git am(保留原始提交信息)
git am 0001-*.patch

或批量导入所有补丁:

git am *.patch

如果出现冲突,可通过:

  • git am --abort 中止操作
  • git am --skip 跳过冲突补丁
  • git am --continue 解决冲突后继续应用

🧰 常用命令整理(速查表)

操作命令示例
导出未提交修改git diff > my.patch
导出最近 N 次提交git format-patch -N
导出某个提交git format-patch -1 <commit-hash>
导出某个分支差异git format-patch origin/main..HEAD
合并多个 patch 为一个cat *.patch > all-in-one.patch
应用普通 patchgit apply my.patch
应用带提交记录的 patchgit am *.patch
撤销 apply 应用git apply -R my.patch
中止 am 应用git am --abort

🎯 进阶:合并多个提交为一个 Patch

如果你有多个已提交的记录想合并为一个 patch,可使用如下方法:

✅ 步骤一:交互式 rebase 合并多个提交

git rebase -i HEAD~3  # 合并最近 3 次提交

将后两个提交改为 squash,保存退出。


✅ 步骤二:导出合并后的单一提交

git format-patch -1 HEAD

✅ 典型场景:迁移提交到另一个仓库

  1. 在源仓库使用 git format-patch 导出提交
  2. 在目标仓库使用 git am 应用补丁
# 在源仓库
git format-patch origin/main..HEAD --output-directory=./patch# 在目标仓库
git am ./patch/*.patch

📌 注意事项

  • 使用 git apply 时不生成提交记录,适合轻量临时修改;
  • 使用 git am 会保留作者、提交信息等元数据;
  • patch 文件应用失败时,一定记得 git am --abort 清理状态;
  • patch 文件内容依赖于当前目录的状态,请保持代码干净。

✅ 小结

工具是否带提交记录是否可撤销应用场景
git diff可(-R)未提交改动的临时导出
git format-patch提交历史导出、离线代码迁移
git apply应用内容变更,轻量修复
git am严谨迁移、有审计需求的场景

相关文章:

  • Mybatis #{} 和 ${}区别,使用场景,LIKE模糊查询避免SQL注入
  • vue前端 多次同步请求一个等一个下载
  • 10.vue.js中封装axioa(3)
  • spring的webclient与vertx的webclient的比较
  • 机器学习——XGBoost
  • Python Einops库:深度学习中的张量操作革命
  • 深度强化学习驱动的智能爬取策略优化:基于网页结构特征的状态表示方法
  • Multi Agents Collaboration OS:Web DeepSearch System
  • delphi7 链表 使用方法
  • 数数科技正式加入上海市人工智能协会,共筑DATA×AI新基建
  • 实数域上的二分
  • UE Learning Record
  • k8S 命令
  • React Navive初识
  • 优化Docker容器化安装与配置的最佳实践
  • Golang面试精解:实现并发安全带过期清理的缓存结构
  • 极限复习c++
  • Spring Plugin框架应用实践:医院多租户客户端动态路由方案解析
  • 【地址区间划分】
  • 【科研绘图系列】R语言绘制和弦图(Chord diagram plot)
  • 如何做公司介绍视频网站/2022最火营销方案
  • 温州大型网站建设/如何制作一个网页页面
  • 玩具网站建设策划书/媒介
  • 徐州市鼓楼区建设局网站/百度论坛首页官网
  • 西安网站建设app建设/营销推广怎么做
  • 惠州的企业网站建设/最好用的搜索引擎