Linux面试指令---diff指令

diff 命令

        类似 comm 命令,diff 命令被用来监测文件之间的差异。然而,diff 是一款更加复杂的工具,它支持许多输出格式,并且一次能处理许多文本文件。软件开发员经常使用 diff 程序来检查不同程序源码版本之间的更改,diff 能够递归地检查源码目录,经常称之为源码树。diff 程序的一个常见用例是创建 diff 文件或者补丁,它会被其它程序使用,例如 patch 程序(我们后面会讲到),来把文件从一个版本转换为另一个版本。

       diff 在命令行中打印每一个行的改动,并且 diff 是 svn、cvs、git 等版本控制工具不可或缺的一部分。diff 命令是 differential 的缩写。

(1)命令格式

         diff [选项] 文件

 

(2)常用参数

参数描述
-c上下文模式,显示全部内文,并标出不同之处
-u统一模式,以合并的方式来显示文件内容的不同
-a只会逐行比较文本文件
-N在比较目录时,若文件 A 仅出现在某个目录中,预设会显示:Only in 目录。 若使用-N 参数,则 diff 会将文件 A 与一个空白的文件比较
-r递归比较目录下的文件

(3)常用范例

         例一:显示 file1.txt 和 file2.txt 两个文件的差异,可以使用如下命令:

diff  file1.txt  file2.txt

       上面结果显示中的“2d1”表示 file1.txt 文件比 file2.txt 文件多了第一行(即file1.txt中多一个b而file2.txt中少一个b 所以第二位置b多一个),“4c3,4”表示 file1.txt 文件的第四行和 file2.txt 文件的第三、四行不同。

diff 的 normal 显示格式有三种提示:

  • a - add
  • c - change
  • d - delete

        例二:从上面例一的显示结果可以知道,file1.txt 和 file2.txt 两个文件的差异不易直观看出,可以使用上下文模式显示,可以使用如下命令:

diff  -c file1.txt  file2.txt

        这个输出结果以两个文件名和它们的时间戳开头。第一个文件用星号做标记,第二个文件用短横线做标记。纵观列表的其它部分,这些标记将象征它们各自代表的文件。

*** 1,4 *** 表示第一个文件中第一行到第四行的文本行。
--- 1,4 --- 表示第二个文件中第一行到第四行的文本行。

三种特殊字符:

+ 添加行,这一行将会出现在第二个文件内,而不是第一个文件内

- 删除行,这一行将会出现在第一个文件中,而不是第二个文件内

! 更改行,将会显示某个文本行的两个版本,每个版本会出现在更改组的各自部分

这些特殊字符很容易混淆,实际上记住一点就行:所有操作目的是将第一个文件变成第二个文件。

        例三:查看 file1.txt 和 file2.txt 两个文件的差异,使用统一模式显示,可以使用如下命令:

diff  -u file1.txt  file2.txt

     上下文模式和统一模式之间最显著的差异就是重复上下文的消除,这就使得统一模式的输出结果要比上下文模式的输出结果简短。

@@ -1,4 +1,4 @@ 表示在在更改组中描述的第一个文件中的文本行和第二个文件中的文本行。

特殊字符:

  • + 添加这一行到第一个文件中
  • - 在第一个文件中删除这一行
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

头脑灵活的胖子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值