Linux下patch的用法【转】
什么是patch
patch即补丁之意,记录文件中的不同,能够与文件进行整合,从而改变文件中的内容。
如何制作patch
在Linux系统中提供了diff程序,可以使用diff程序,比较文件之间的不同从而制作出patch文件
- 在系统中(我用的是Ubuntu)创建diff文件夹,创建test1.txt,test2.txt
mkdir diff vi test1.txt vi test2.txt
test1.txt文件内容如下
aaaa
test2.txt文件内容如下
aaaa bbbb
- 使用diff命令制作patch文件
-
diff -Naur test1.txt test2.txt > test.patch
之后在当前目录中会存在三个文件
test1.txt test2.txt test.patch
test.patch 文件的内容
--- test1.txt 2018-08-01 13:17:33.530350672 +0800 +++ test2.txt 2018-08-01 13:18:54.326350260 +0800 @@ -1 +1,2 @@ aaaa +bbbb
diff参数解释
-N 在比较目录时如果某个文件只出现了一次,那么在比较不同时会默认和空文件比较
-a 将所有的文件都作为普通text(之比较文本文件)
-u 以合并的方式显示文件内容的不同
-r 如果是文件夹则进行递归进行比较
如何使用patch
- 准备好patch文件和原版本文件
创建patch文件夹,将test1.txt 和test.patch文件拷贝进去
mkdir patch
cp test1.txt test.patch../patch/
- 执行patch命令
patch -p0 < test.patch
3.test1.txt文件内容如下
aaa bbb
可以看到patch已经打进去了
参数介绍:
patch命令中最常用的就是-pX这个参数
在上面我们注意到patch文件如下内容
--- test1.txt 2018-08-01 13:17:33.530350672 +0800
此时我们的参数为-p0,此时patch 就会在当前目录下寻找test1.txt文件,如在在patch文件中是这样记录的
---a/b/test1.txt 2018-08-01 13:17:33.530350672 +0800
那么-p0会在当前目录下寻找a目录,a目录下寻找b,之后在b中寻找test1.txt文件。
如果是 -p1,patch命令就会舍弃a,先寻找b再寻找test1.txt
如果是-p2 ,会舍弃a/b,直接寻找test1.txt
所以-pX中 X代表就是所要舍弃的层级目录
补充:
-p0 选项要从当前目录查找目的文件(夹)
-p1 选项要忽略掉第一层目录,从当前目录开始查找。
************************************************************
在这里以实例说明:
---old/modules/pcitable Mon Sep 27 11:03:561999
+++new/modules/pcitable Tue Dec 19 20:05:412000
如果使用参数-p0,那就表示从当前目录找一个叫做old的文件夹,在它下面寻找modules下的pcitable文件来执行patch操作。
如果使用参数-p1,那就表示忽略第一层目录(即不管old),从当前目录寻找modules的文件夹,在它下面找pcitable。
这样的前提是当前目录必须为modules所在的目录。而diff补丁文件则可以在任意位置,只要指明了diff补丁文件的路径就可以了。
当然,可以用相对路径,也可以用绝对路径。不过我一般习惯用相对路径。
************************************************************
-E 选项说明如果发现了空文件,那么就删除它
-R 选项说明在补丁文件中的“新”文件和“旧”文件现在要调换过来了(实际上就是给新版本打补丁,让它变成老版本)
简单的示例:
方式一:$patch File0.cpp diff.patch
方式二:$patch -p0 < diff.patch
通过下面的命令,可以去除补丁,恢复旧版本
$ patch -RE -p0 < diff.patch
patch文件的结构
(1)补丁头:
补丁头是分别由---/+++开头的两行,用来表示要打补丁的文件。---开头表示旧文件,+++开头表示新文件。
(2)块:
块是补丁中要修改的地方。它通常由一部分不用修改的东西开始和结束。他们只是用来表示要修改的位置。他们通常以@@开始,结束于另一个块的开始或者一个新的补丁头。
块的缩进:块会缩进一列,而这一列是用来表示这一行是要增加还是要删除的。
块的第一列:
+号表示这一行是要加上的。
-号表示这一行是要删除的。
没有加号也没有减号表示这里只是引用的而不需要修改。
--- File0.cpp 2013-08-01 13:40:35.579447633 +0800 +++ File1.cpp 2013-08-01 13:41:04.609447640 +0800 @@ -1 +1 @@ -The First file. +The Second File.
patch还有很多参数,但是-pX是最为常用的
简单的说,patch就是利用diff制作的补丁来实现源文件(夹)和目的文件(夹)的转换。这样说就意味着你可以由源文件(夹)――>目的文件(夹),也可以由目的文件(夹)――>源文件(夹)。
patch的应用场景
patch多用于系统升级,只要有一个基础版本,以及基于这个版本的一些patch,就可以进行升级。
转自:https://www.cnblogs.com/paul8339/p/11598782.html 仅供参考学习使用。
本文来自博客园,作者:白菜没我白,转载请注明原文链接:https://www.cnblogs.com/xingboy/p/15954771.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!