git生成及应用补丁

文章目录

    • 简述
    • 补丁生成
      • [git diff](#git diff)
      • [git show](#git show)
      • [git format-patch](#git format-patch)
    • 应用补丁
      • [git apply](#git apply)
      • [git am](#git am)

简述

git补丁是对代码库的改动的一种表述形式,它可以帮助你将代码库的修改分享给其他人,而不需要对整个代码库进行复制。

补丁生成

git diff

使用 git diff 命令可以生成补丁。例如,如果你想创建一个包含最后一次提交改动的补丁文件,你可以使用以下命令:

复制代码
git diff HEAD^..HEAD > mypatch.patch

上述命令会将最后一次提交(HEAD)与倒数第二次提交(HEAD^)之间的改动输出到名为 mypatch.patch 的文件中。

同样,你也可以为特定的文件或者目录生成补丁:

复制代码
git diff > patchfile        # 生成工作区和暂存区间的改动
git diff --cached > patchfile   # 生成暂存区和最近提交间的改动
git diff HEAD > patchfile   # 生成工作区和最近提交间的改动
git diff test.py > test.patch  # 生成test.py文件的改动

git show

这个命令可以用来显示某个提交的补丁。

例如,你可以使用以下命令来输出特定提交的补丁:

复制代码
git show COMMIT > patch

git format-patch

git format-patch命令也可以生成补丁文件。与git diff稍有不同,git format-patch命令生成的补丁文件包含提交信息,作者,提交日期等更多信息,而且每一个提交都会生成一个单独的补丁文件。

复制代码
git format-patch HEAD^       #生成最近的1次commit的patch
git format-patch HEAD^^      #生成最近的2次commit的patch
git format-patch HEAD^^^     #生成最近的3次commit的patch
git format-patch HEAD^^^^    #生成最近的4次commit的patch
git format-patch <r1>..<r2>  #生成两个commit间的修改的patch(生成的patch不包含r1. <r1>和<r2>都是具体的commit号)
git format-patch -1 <r1>     #生成单个commit的patch
git format-patch <r1>        #生成某commit以来的修改patch(不包含该commit)
git format-patch --root <r1> #生成从根到r1提交的所有patch

应用补丁

git apply

这个命令用来应用由git diff或git show生成的补丁。这个命令仅将补丁的修改应用到工作目录中,而不会创建新的commit。如果你想将这些更改提交到你的仓库,你需要手动添加和提交这些更改。

复制代码
git apply mypatch.patch

此命令将应用名为 mypatch.patch 的补丁文件的改动到当前的Git仓库。

注意: 生成的补丁文件是文本文件,你可以使用任何文本编辑器查看它们的内容。结构清晰的补丁文件即使是人也能够阅读并理解其中记录的代码变更

git am

这个命令主要用来应用由git format-patch生成的补丁文件。这个命令将每个补丁文件都应用成一次新的提交,并且自动采用补丁文件中的提交信息,包括作者信息、提交日期等。

复制代码
git am mypatch.patch    # 应用补丁并自动创建新的提交
相关推荐
不爱吃糖的程序媛1 小时前
鸿蒙三方库适配读懂 `thirdparty/AES/.gitignore`:哪些文件不该进 Git?
git·elasticsearch·harmonyos
天若有情67314 小时前
【C++原创开源】formort.h:一行头文件,实现比JS模板字符串更爽的链式拼接+响应式变量
开发语言·javascript·c++·git·github·开源项目·模版字符串
海盗123415 小时前
在群晖NAS上使用Git Server
git
y小花15 小时前
git常用指令
git
华科大胡子16 小时前
开源项目 Git 贡献全流程拆解
git
极地星光16 小时前
工程中:Git 子模块(submodule) vs 直接依赖(源码/库/包管理器)
git
无限进步_17 小时前
【C++&string】大数相乘算法详解:从字符串加法到乘法实现
java·开发语言·c++·git·算法·github·visual studio
无限进步_18 小时前
【C++】验证回文字符串:高效算法详解与优化
java·开发语言·c++·git·算法·github·visual studio
无限进步_21 小时前
【C++】重载、重写和重定义的区别详解
c语言·开发语言·c++·ide·windows·git·github
历程里程碑21 小时前
1 . Git本地操作:版本控制 跨平台协作 仓库核心
java·开发语言·数据结构·c++·git·gitee·github