2.12 diff:比较两个文件
作用:diff命令可以找出两个文件的不同点。
用法:diff [选项] 源文件 目标文件
主要选项如下。
● -<行数>:指定要显示多少行的文本。此参数必须与-c或-u参数一并使用。
● -a或--text:diff预设只会逐行比较文本文件。
● -b或--ignore-space-change:不检查空格字符的不同。
● -B或--ignore-blank-lines:不检查空白行。
● -c:显示全部内文,并标出不同之处。
● -C<行数>或--context<行数>:与执行“c-<行数>”命令相同。
● -d或--minimal:使用不同的演算法,以较小的单位来做比较。
● -D<巨集名称>或ifdef<巨集名称>:此参数的输出用法可用于前置处理器巨集。
● -e或--ed:此参数的输出用法可用于ed的script文件。
● -f或-forward-ed:输出的用法类似于ed的script文件,但按照原来文件的顺序显示不同处。
● -H或--speed-large-files:比较大文件时,可加快速度。
● -l<字符或字符串>或--ignore-matching-lines<字符或字符串>:若两个文件在某几行有所不同,而这几行同时都包含了选项中指定的字符或字符串,则不显示这两个文件的差异。
● -i或--ignore-case:不检查大小写的不同。
● -l或--paginate:将结果交由pr程序来分页。
● -n或--rcs:将比较结果以RCS的用法来显示。
● -N或--new-file:在比较目录时,若文件A仅出现在某个目录中,预设会显示如下内容。
● Only in目录:文件A若使用-N参数,则diff会将文件A与一个空白的文件进行比较。
● -p:若比较的文件为C语言的程序码文件,显示差异所在的函数名称。
● -P或--unidirectional-new-file:与-N类似,但只有当第二个目录包含了一个第一个目录所没有的文件时,才会将这个文件与空白的文件做比较。
● -q或--brief:仅显示有无差异,不显示详细的信息。
● -r或--recursive:比较子目录中的文件。
● -s或--report-identical-files:若没有发现任何差异,仍然显示信息。
● -S<文件>或--starting-file<文件>:在比较目录时,从指定的文件开始比较。
● -t或--expand-tabs:在输出时,将tab字符展开。
● -T或--initial-tab:在每行前面加上tab字符以便对齐。
● -u,-U<列数>或--unified=<列数>:以合并的方式来显示文件内容的不同。
● -v或--version:显示版本信息。
● -w或--ignore-all-space:忽略全部的空格字符。
● -W<宽度>或--width<宽度>:在使用-y参数时,指定栏宽。
● -x<文件名或目录>或--exclude<文件名或目录>:不比较选项中所指定的文件或目录。
● -X<文件>或--exclude-from<文件>:可以将文件或目录类型存成文本文件,然后在=<文件>中指定此文本文件。
● -y或--side-by-side:以并列的方式显示文件的异同。
● --help:显示帮助。
● --left-column:在使用-y参数时,若两个文件某一行内容相同,则仅在左侧的栏位显示该行内容。
● --suppress-common-lines:在使用-y参数时,仅显示不同之处。
说明:diff以逐行的方式比较文本文件的异同处。如果源文件和目标文件都是目录,则diff比较两个目录中相应的文件,依照字母次序排序。diff的输出用法有三种,包括列举模式、命令模式和上下文模式,其中命令模式又分为两种,即ed命令模式和RCS(Revision Control System,版本控制系统)命令模式。
应用实例如下。
使用并排(side-by-side)用法查看文件差异,如图2-5所示。
图2-5 并排(side-by-side)用法输出
这是两个相似又有所不同的文件:hello.cpp和hello1.cpp,使用并排(side-by-side)用法可以直观地比较源代码文件的差异。尽管出现了截行,还是可以非常清楚地显示两个文件的区别。-W选项指定输出列的宽度。diff接受这个宽度,并且分配给两个文件各40行。字符“>”表示该行在目的文件中,“<”表示该行在源文件中,字符“|”标记出两个文件中不相同的行。