diff制作补丁文件的原理:告诉我们怎么修改第一个文件后能得到第二个文件。

diff命令常用选项:

-u 输出统一内容的头部信息(打补丁使用),计算机知道是哪个文件需要修改    -r 递归对比目录中的所有资源(可以对比目录)

-a 所有文件视为文本(包括二进制程序)      -N 无文件视为空文件(空文件怎么变成第二个文件)

patch  -pnum(其中num为数字,指定删除补丁文件中多少层路径前缀)

如原始路径为/u/howard/src/blurfl/blurfl.c

-p0则整个路径不变     -p1则修改路径为u/howard/src/blurfl/blurfl.c     -p4则修改路径为blurfl/blurfl.c

-R(reverse)反向修复    -E修复后如果文件为空,则删除该文件

patch对单文件代码打补丁

[root@proxy ~]# cd demo

[root@proxy demo]# vim test1.sh    //v1版本脚本

#!/bin/bash

echo "hello world"

echo "test"

[root@proxy demo]# vim test2.sh   //v2版本脚本

#!/bin/bash

echo "hello the world"

echo "test file"

[root@proxy demo]# diff -u test1.sh test2.sh > test.patch   //diff生成补丁文件

[root@proxy demo]# yum -y install patch       //安装patch软件包

[root@proxy demo]# patch -p0 < test.patch                    //在代码相同目录下为代码打补丁

patching file test1.sh

[root@proxy demo]# patch -RE < test.patch                     //还原旧版本,反向修复

patch对目录下的所有代码打补丁

[root@proxy ~]# mkdir demo

[root@proxy ~]# cd demo

[root@proxy demo]# mkdir {source1,source2}

[root@proxy demo]# echo "hello world"  > source1/test.sh     //source1目录及文件

[root@proxy demo]# cp /bin/find  source1/

[root@proxy demo]#  tree source1/                        //source1目录下2个文件

|-- find

`-- test.sh

[root@proxy demo]# echo "hello the world"  > source2/test.sh    //source2目录及文件

[root@proxy demo]# echo "test" > source2/tmp.txt

[root@proxy demo]# cp /bin/find  source2/

[root@proxy demo]# echo "1" >> source2/find

[root@proxy demo]#  tree source2/                        //source1目录下3个文件

|-- find

|-- test.sh

`-- tmp.txt

[root@proxy demo]# diff -Nuar source1/ source2/ > source.patch   //生成补丁

[root@proxy demo]# ls

source1  source2  source.patch

[root@proxy demo]# cat source.patch                //对比的文件有路径信息

--- source1/test.sh 2018-02-07 22:51:33.034879417 +0800

+++ source2/test.sh 2018-02-07 22:47:32.531754268 +0800

@@ -1 +1 @@

-hello world

+hello the world

[root@proxy demo]# cd source1

[root@proxy source1]# patch  -p1 < ../source.patch

十一、diff和patch打补丁的更多相关文章

  1. diff和patch 打补丁

    在Linux环境下,有两个工具用来给project打补丁,即diff和patch diff         diff具有比较功能.可以使用man命令查看其使用方法. NAME        diff ...

  2. [daily] 使用diff和patch打补丁

    diff org new > xxx.patch patch /path/org xxx.patch /path/org是相对路径时, 会报错. 这是一个bug.

  3. diff生成补丁与patch打补丁

    1.使用diff生成补丁: diff是Linux下的文件比较命令,参数这里就不说了,直接man一下就行了,不仅可以比较文件,也可以比较两个目录,并且可以将不同之处生成补丁文件,其实就是一种打补丁的命令 ...

  4. patch 打补丁,和diff 生成制作补丁

    一.diff 命令: diff命令就是比较两个文件的差异,然后生成差异文件,即补丁文件. 参数:diff --help获得,最常用的 1.-N --new-file 在比较时,如果没有就拿一个空的文件 ...

  5. git apply、git am打补丁.diff 和 .patch【转】

    本文转载自:https://www.jianshu.com/p/e5d801b936b6 前提: 生成patch: git format-patch -M master 生成指定patch,0163b ...

  6. diff和patch的使用、patch文件的格式解说

    为了弄懂 patch中的 p0   p1    和.orig文件是啥,找到了这篇文章! 来源:http://www.cnblogs.com/super119/archive/2010/12/18/19 ...

  7. 【转】Linux下patch打补丁命令

    [转]Linux下patch打补丁命令 转自:http://www.cnblogs.com/noaming1900/archive/2010/10/28/1863282.html 此命令用于为特定软件 ...

  8. Linux下patch打补丁命令

    此命令用于为特定软件包打补丁,他使用diff命令对源文件进行操作. 基本命令语法: patch [-R] {-p(n)} [--dry-run] < patch_file_name p:为pat ...

  9. 关于 diff 和patch

    参考: https://blog.csdn.net/zygblock/article/details/53384862 diff和patch是 版本控制 git 的不可缺少的工具 diff 是用来比较 ...

随机推荐

  1. git的一些常用命令总结

    1.拉取代码Git clone  "链接名称" 2.新建分支 git checkout -b "分支名称" 3.提交代码步骤 (1)Git status查看项目 ...

  2. Xshell、Xftp评估过期的解决办法

    介绍一个     FTP客户端-IIS7服务器管理工具作为FTP客户端,它支持批量管理ftp站点.定时上传和定时下载,定时备份,且操作简洁.同时iis7服务器管理工具还是vnc客户端.并且支持批量管理 ...

  3. php基础-php中使用变量

  4. 合并两个yuv文件的C++代码

    //将BasketballPass_416x240_50.yuv序列的前50帧和BlowingBubbles_416x240_50.yuv序列的前250帧合并成out.yuv //参数配置416 24 ...

  5. shell中的 “.”和source export

    在shell脚本里面export的环境变量,在set里面竟然看不到.为什么在shell脚本里面用export设置环境变量之后,当shell执行完了,用set命令看不到呢?但是你如果直接在终端里expo ...

  6. [Qt] 事件机制(四)

    滚轮事件:滚动滚轮实现窗口大小缩放 widget.h中增加: protected: void wheelEvent(QWheelEvent *event) Q_DECL_OVERRIDE; void ...

  7. CSS中的颜色、长度、角度、时间

    一.颜色的表示方法 颜色是通过对红.绿和蓝光的组合来显示的. 1.颜色名 1 <!DOCTYPE html> 2 <html lang="en"> 3 &l ...

  8. 保姆级别的RabbitMQ教程!一看就懂!(有安装教程,送安装需要的依赖包,送Java、Golang两种客户端教学Case)

    保姆级别的RabbitMQ教程!一看就懂!(有安装教程,送安装需要的依赖包,送Java.Golang两种客户端教学Case)   目录 什么是AMQP 和 JMS? 常见的MQ产品 安装RabbitM ...

  9. echo "This is line $LINENO"返回行号

    echo "This is line $LINENO"返回行号 LINENO 变量LINENO返回它在脚本里面的行号. #!/bin/bash echo "This is ...

  10. Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redhat 7)

    Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redhat 7) 您多久访问一次Linux桌面? 您使用什么工具来访问远程桌面? Xrdp是一个开源工具, ...