该命令的功能为逐行比较两个文本文件,列出其不同之处。它比comm命令完成更复杂的检查。它扒辩对给出的文件进行系统的检查,并显示出两个文件中所有不同的行,不要求事先对文件进行排序。
语法:diff [选项] file1 file2
说明:该命令告诉用户,为了使两个文件file1和file2一致,需要修改它们的哪些行。如果用“- ”表示file1或fiie2,则表示标准输入。如果file1或file2是目录,那么diff将使用该目录中的同名文件进行比较。
例如: diff /usr/xu mine
把目录/usr/xu 中名为mine的文件与当前目录中的mine文件进行比较。
通常输出由下述形式的行组成:
n1 a n3,n4
n1,n2 d n3
n1,n2 c n3,n4 这些行类似ed命令把filel转换成file2。字母(a、d和c)之前的行号(n1,n2)是针对file1的,其后面的行号(n3,n4)是针对file2的。字母a、d和c分别表示附加、删除和修改 *** 作。
在上述形式的每一行的后面跟随受到影响的若干行,以“<”打头的行属于第一个文件,以“>”打头的行属于第二个文件。
diff能区别块和字符设备文件以及FIFO(管道文件),不会把它们与普通文件进行比较。
如果file1和file2都是目录,则diff会产生很多信息。
如果一个目录中只有一个文件,则产生一条信息,指颤唯出该目录路径名和其中的文件名。
diff各选项的含义如下:
- b 忽略行尾的空格,而字符串中的一个或多个空格符都视为相等。
如How are you与How are you被视为相同的字符串。
- c 采用上下文输出格式(提供三行上下文)。
- C n 采用上下文输出格式(提供n行上下文)。
- e 产生一个合法的ed脚本作为输出。
- r 当file1和file2是目录时,递归作用到各文件和目录上。
例如,文件ml.c的内容为(左边行号是有意加上的,以便前后对照):
1 main( )
{
printf(“Hello!\n”);
}
5 文件m2.c的内容为:
1 main()
2 {
3 int n , m
4 n= 10
5 printf ( “ % d \\\\ n ” , m = n * 10)
6 }
输入命令:
$ diff m1.c m2.c
屏幕上显示:
3,5 c 3,6
printf(“Hello!\n”);
}
<5
>3
int n,m;
>4 n=10
>5 printf ( “ % d \\\\ n ” , m = n * 10)
>6 }
表示把文茄此培件m1.c的3至5行改成m2.c的3至6行后,两个文件相同。
diff 命令是 linux上非常重要的工具,用于比较文件的内容,特别是比较两个版本不同的文件以找到改动的地方。diff在命令行中打印每一个行的改动。最新版本的diff还支持二进制文件。diff程序的输出被称为补丁 (patch),因为Linux系统中还有一个patch程序,可以根据diff的输出将a.c的文件内容更新为b.c。diff是svn、cvs、git等版本控制工具不可或缺的一部分。
diff命令的格式一般为:
diff [参数][文件或者目录1][文件或者目录2]
例如,有文件凯竖历test1和test2:
将会输出:
格式的含义如注释所示。
diff 的normal 显示格式有三种提示:
a - add
c - change
d - delete
比较常用的是以合并的方式显示两个文件的不同:
输出如:
这种输出方式输出的内容可以用于使用patch命令进行打补丁包。patch命令我们稍后再看。
diff命令也可以比较两个文件夹的不同:
例如有两个文件夹testa和纤嫌test,将test1和test2放进去:
得到:
第一部分是文件的信息
"---"表示变动前的文件,"+++"表示变动后的文件。
第二部分表示变动的位置
@@ -1,11 +1,5 @@
减号表示第一个文件,后面的表示第一行起一共11行。加号表示第二个文件。后面是第一行起一共5行。
接下来的表示区别的部分。
例如:
将得到:
这种模式中
“|”表示前后2个文件内容有不同
“<”表示后面文件比前面文件少了1行内容
“>”表示后面文件比前面文件多了1行内容
我们可以先用diff命令生成patch文件。然后使用patch命令将第二盯搜个文件内容修改成第一个文件的内容。
例如上述的test1和test2:
之后test2的内容就会和test1内容一致了。
svn diff生成的patch也可以用于更新文件
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)