Linux提供diff、diff -u、vimdiff、cmp和git diff五种文件差异比对方法:diff逐行比对文本,diff -u生成统一格式,vimdiff可视化双窗,cmp字节级比对二进制文件,git diff用于版本控制场景。

如果您需要检查两个文件在内容上是否存在不同,Linux系统提供了多种命令行工具来实现这一目的。其中,diff 是最常用且功能强大的文本差异比对工具。以下是几种实用的文件差异比较方法:
一、使用 diff 命令逐行对比
diff 命令通过逐行比较两个文件的文本内容,输出差异位置及类型(新增、删除、修改),适用于纯文本文件的精确比对。
1、打开终端,进入包含待比较文件的目录。
2、输入命令:diff file1.txt file2.txt。
3、若无输出,表示两文件内容完全一致;若有输出,则显示以 a(add)、c(change)、d(delete) 开头的差异行及对应行号。
二、使用 diff -u 生成统一格式差异
统一格式(unified format)将上下文行与变化行合并显示,便于阅读和后续处理(如打补丁),是开源协作中广泛采用的标准格式。
1、在终端中执行:diff -u file1.txt file2.txt。
2、输出以 @@ 行标记差异块起始位置,前缀 - 表示仅存在于第一个文件的行,+ 表示仅存在于第二个文件的行。
三、使用 vimdiff 进入可视化双窗口比对
vimdiff 是 Vim 编辑器提供的内置差异比对模式,支持高亮显示差异、交互式编辑与同步滚动,适合需人工审阅或修改的场景。
1、在终端中运行:vimdiff file1.txt file2.txt。
2、界面左右分屏显示两个文件,差异行以颜色高亮并标注 +/- 符号。
3、按 :qa! 退出比对视图(不保存更改)。
四、使用 cmp 命令进行二进制级字节比对
cmp 命令逐字节比较两个文件,适用于所有类型文件(包括二进制文件),可精确定位首个不同字节的位置。
1、执行命令:cmp file1.bin file2.bin。
2、若文件相同,无任何输出;若不同,显示首个差异字节的十进制偏移量及对应 ASCII 值。
3、添加 -l 参数可列出所有不同字节及其位置:cmp -l file1.bin file2.bin。
五、使用 git diff 快速比对工作区与暂存区/版本库文件
当文件位于 Git 仓库中时,git diff 可直接比对不同状态下的文件版本,无需手动指定完整路径,且自动识别编码与换行符差异。
1、确保当前目录为 Git 仓库根目录。
2、执行:git diff -- file1.txt 比对工作区与暂存区差异。
3、执行:git diff HEAD -- file1.txt 比对工作区与最近一次提交的差异。










