博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
patch补丁文件格式
阅读量:4159 次
发布时间:2019-05-26

本文共 1225 字,大约阅读时间需要 4 分钟。

linux补丁文件格式

“补丁” 指的是文件之间一系列差异。

在原始文件的基础上进行修改后,然后根据所做的修改生成补丁文件(使用diff命令)。

一个持有原始文件的人,将该补丁打到原始文件上(使用patch命令),就变成了修改后的文件。

1. 创建两个实验文件

  • 原文件:1.txt
this is a testfor patch file formatso let us go!
  • 修改后的文件:2.txt
this is a testfor linux patch file formatso let us go!learn it

2. 生成补丁文件

diff -u 1.txt 2.txt > diff.patchvim diff.patch

生成的补丁文件内容如下:

1 --- 1.txt       2020-07-20 16:45:27.131654289 +08002 +++ 2.txt       2020-07-20 16:46:26.348728016 +08003 @@ -1,3 +1,4 @@4  this is a test5 -for patch file format6 +for linux patch file format7  so let us go!8 +learn it

3.补丁头

1 --- 1.txt       2020-07-20 16:45:27.131654289 +08002 +++ 2.txt       2020-07-20 16:46:26.348728016 +0800

“—” 表示旧文件(原文件)

“+++” 表示新文件(修改后的文件)

补丁头记录了原始文件和修改后的文件的文件名和创建时间。

4.块

补丁中的块是用来说明文件的改动情况。他们通常以@@开始,结束于另一个块的开始或者一个新的补丁头

3 @@ -1,3 +1,4 @@4  this is a test5 -for patch file format6 +for linux patch file format7  so let us go!8 +learn it

5.块的缩进

3 @@ -1,3 +1,4 @@4  this is a test5 -for patch file format6 +for linux patch file format7  so let us go!8 +learn it

块会缩进一列,该列有三种情况:

  • 以 “-” 开头的行,表示改行只在原始文件中存在,比如第5行

  • 以 “+” 开头的行,表示改行只在修改后的文件中存在,比如第6行和第8行

  • 以空格开头的行,表示改行在原始文件和修改后的文件中都存在,比如第4行和第7行

从打补丁的角度来看,这一列是用来表示这一行是要增加还是要删除的;

  • 以 “-” 开头的行是要删除的

  • 以 “+” 开头的行是要加上的

  • 以空格开头的行保持不变

转载地址:http://qxbxi.baihongyu.com/

你可能感兴趣的文章
oracle执行计划详解
查看>>
[Hive]Lateral View使用指南
查看>>
定时任务crontab 详解
查看>>
HIVE基础操作(命令,表,数据导出导入等)--持续更新
查看>>
HBASE基础命令
查看>>
HIVE分区常用操作
查看>>
hbase 和 hive 关联表
查看>>
hive和hbase数据相互关联
查看>>
hbaseAPI中 rowkey使用整数表示的结果
查看>>
hbaseAPI 命名空间
查看>>
hbaseAPI 针对表操作 ddl
查看>>
hbaseAPI DML数据增删改
查看>>
c3p0的使用
查看>>
从hdfs中插入数据到hbase中
查看>>
从Hbase传输数据到Hdfs
查看>>
从hbase到hbase数据传输
查看>>
HBase--通过Java API与HBase交互(增删改)
查看>>
hive中分区表(partition table):动态分区(dynamic partition)和 静态分区(static partition)
查看>>
hive-表生成函数
查看>>
Hive性能调校
查看>>