Linux diff命令

Linux中diff命令用于比较文件的差异,一般用于制作补丁文件。

比较两个文件

diff -u from-file to-file >file.patch

-r 用于比较目录时表示递归比较子目录的内容

-N 如果目录中有新增文件也加入比较

例如,我们有两个目录a和b,里面就一个文件hello.c,文件内容分别如下:

#include <stdio.h>

int main(void)
{
	return 0;
}
#include <stdio.h>

int main(void)
{
	printf("hello world\n");
	return 0;
}
在b目录中只是将hello.c增加了这么一行:
printf("hello world\n");

那么我们怎么来为a目录生成patch文件呢,首先进入到b目录中,命令如下:
diff -u ../a . > patch.file

patch.file文件内容如下:
diff -u ../a/hello.c ./hello.c
--- ../a/hello.c	2016-04-11 23:09:21.925034458 +0800
+++ ./hello.c	2016-04-11 23:09:31.901083951 +0800
@@ -2,5 +2,6 @@
 
 int main(void)
 {
+	printf("hello world\n");
 	return 0;
 }
Only in .: patch.file
加号表示增加的内容,如果有减号表示减少的内容,注意老的,或者旧的目录要写在前面。


patch文件是生成了,那么如何来打patch呢。

首先将patch文件拷贝到a目录中去,使用下面的命令来打patch:
patch -p0 < patch.file

如果要取消此次patch,使用命令:
patch -R < patch.file
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值