# Linux diff命令使用

Linux diff命令使用

1. 命令概述

diff(difference缩写)是Linux/Unix系统中逐行比较两个文本文件/目录内容差异的核心命令,适用于代码审查、配置文件对比、版本控制和补丁生成等场景。

  • 核心功能:比较两个文件/目录,输出差异位置与修改建议
  • 适用范围:仅支持文本文件,二进制文件提示"Binary files differ"
  • 退出状态:
    • 0:无差异
    • 1:存在差异
    • 2:执行错误(如文件不存在)

2. 基本语法

bash 复制代码
diff [选项] 源文件/目录 目标文件/目录
  • 源文件:作为对比基准的文件/目录
  • 目标文件:待对比的文件/目录
  • 选项:控制输出格式与比较规则

3. 常用选项

选项 全称 功能描述
-u --unified[=NUM] 统一格式输出(默认3行上下文),推荐用于补丁生成
-r --recursive 递归比较目录及子目录内容
-q --brief 仅显示文件是否不同,不输出具体差异
-i --ignore-case 忽略大小写差异
-w --ignore-all-space 忽略所有空白字符差异
-y --side-by-side 左右并排显示文件差异
-N --new-file 将不存在的文件视为空文件(目录比较常用)

4. 输出格式解析

4.1 默认格式(ed脚本格式)

输出修改指令,说明如何修改源文件匹配目标文件:

bash 复制代码
# 示例:对比file1.txt和file2.txt
diff file1.txt file2.txt
# 输出格式:
行号范围 操作符 行号范围
< 源文件内容行
---
> 目标文件内容行
  • 操作符:
    • a(add):源文件需添加内容
    • d(delete):源文件需删除内容
    • c(change):源文件需修改内容

4.2 统一格式(-u,推荐)

清晰简洁,含上下文与文件信息:

bash 复制代码
diff -u file1.txt file2.txt
# 输出示例:
--- file1.txt  2026-02-13 10:00:00
+++ file2.txt  2026-02-13 10:01:00
@@ -1,3 +1,4 @@
-1. Apple
+1. apple
 2. Banana
-3. Cherry
+3. Orange
+4. Mango
  • ---:源文件标识
  • +++:目标文件标识
  • -:源文件删除行
  • +:目标文件添加行

4.3 并排格式(-y)

左右对比显示差异:

bash 复制代码
diff -y file1.txt file2.txt
# 输出示例:
1. Apple                                 | 1. apple
2. Banana                                2. Banana
3. Cherry                                | 3. Orange
                                         > 4. Mango

5. 实用示例

5.1 文件比较

bash 复制代码
# 基础对比
diff file1.txt file2.txt
# 忽略大小写和空白
diff -iw file1.txt file2.txt
# 仅显示是否不同
diff -q file1.txt file2.txt

5.2 目录比较

bash 复制代码
# 递归比较目录
diff -r dir1 dir2
# 简洁模式递归比较
diff -rq dir1 dir2
# 处理新文件的递归比较
diff -rN dir1 dir2

5.3 补丁生成与应用

bash 复制代码
# 生成统一格式补丁
diff -u file1.txt file2.txt > changes.patch
# 应用补丁
patch file1.txt < changes.patch
# 反向恢复补丁
patch -R file1.txt < changes.patch

6. 注意事项

  • diff对二进制文件仅提示差异,无具体内容
  • 文件顺序影响输出(输出为"修改源文件匹配目标文件"的指令)
  • 大文件对比建议结合其他工具(如sdiff)
  • 确保对比文件编码一致,避免乱码或误判
相关推荐
斯班奇的好朋友阿法法17 小时前
中科方德(NFSChina)离线安装 RPM 包
运维
milo.qu18 小时前
RockyLinux9.7 docker部署Jisti Meet
linux·docker·容器
GanGanGanGan_18 小时前
CentOS 7.9 glibc 2.17 源码编译升级到 glibc 2.31
linux·运维·centos·glibc
charlie11451419118 小时前
嵌入式Linux驱动开发——class 和 device 模型 - 自动创建设备节点的幕后机制
linux·运维·驱动开发
杨云龙UP19 小时前
SQL Server2022部署:Windows Server 2016下安装、SSMS配置、备份还原与1433端口放通全流程_20260508
运维·服务器·数据库·sql·sqlserver·2022
梦想与想象-广州大智汇20 小时前
自建docker加速镜像,使用 Cloudflare Workers/Pages 部署加速教程
运维·docker·容器
枳实-叶20 小时前
【Linux驱动开发】第四天:dmesg日志全解+驱动加载失败极速排查
linux·运维·驱动开发
武超杰20 小时前
Nginx从入门到精通
运维·nginx
wdfk_prog20 小时前
正常关闭虚拟机时,不要点“关机”,而要点“关闭客户机”
linux·c语言·网络·ide·vscode
weixin_7042660520 小时前
Nginx 反向代理 + 6 种负载均衡策略
运维·nginx