常用的git diff命令用法汇总和示例

文章目录

      • [1. 查看工作目录和暂存区的差异](#1. 查看工作目录和暂存区的差异)
      • [2. 查看暂存区和最后一次提交的差异](#2. 查看暂存区和最后一次提交的差异)
      • [3. 查看两个提交之间的差异](#3. 查看两个提交之间的差异)
      • [4. 查看特定文件的更改](#4. 查看特定文件的更改)
      • [5. 查看特定文件在两个提交之间的差异](#5. 查看特定文件在两个提交之间的差异)
      • [6. 查看分支之间的差异](#6. 查看分支之间的差异)
      • [7. 查看某次提交的更改](#7. 查看某次提交的更改)
      • [8. 限制diff输出的格式](#8. 限制diff输出的格式)
      • [9. 查看一定时间范围内的更改](#9. 查看一定时间范围内的更改)

Git的diff命令是一种强大的工具,用于比较Git仓库中文件的更改。以下是一些常用的git diff命令用法和示例:

1. 查看工作目录和暂存区的差异

bash 复制代码
git diff

这个命令显示自上次git add以来,在工作目录中对文件所做的未暂存的更改。

2. 查看暂存区和最后一次提交的差异

bash 复制代码
git diff --staged

或者

bash 复制代码
git diff --cached

这些命令显示自上次git commit以来,暂存区中的文件与最后一次提交的差异。

3. 查看两个提交之间的差异

bash 复制代码
git diff commit1 commit2

这里commit1commit2是两个提交的哈希值或引用。该命令显示两次提交之间的差异。

要对比两个特定的 Git 提交(例子是 e28efea6f14d41),可以使用 Git 的 diff 命令。这个命令会显示两次提交之间代码的具体更改(添加、删除或修改的行)。

在终端或命令提示符中,您可以使用以下命令来对比这两个提交:

bash 复制代码
git diff 6f14d41 e28efea

这里,6f14d41e28efea 是两个提交的哈希值。这个命令将展示自从 6f14d41 之后,直到 e28efea 所发生的所有更改。

输出结果会显示所有更改的详细内容,其中:

  • 以绿色(并且前面有 + 号)显示的是添加的行。
  • 以红色(并且前面有 - 号)显示的是删除的行。

如果您只对比这两个提交中某个特定文件的差异,可以在命令中指定文件名:

bash 复制代码
git diff 6f14d41 e28efea -- [文件路径]

请替换 [文件路径] 为您要比较的具体文件路径。

使用这个方法,您可以清楚地看到两个版本之间的代码差异,这对于了解特定更改的性质和影响非常有帮助。

4. 查看特定文件的更改

bash 复制代码
git diff [文件路径]

显示自上次git add以来,指定文件的更改。

5. 查看特定文件在两个提交之间的差异

bash 复制代码
git diff commit1 commit2 -- [文件路径]

显示两个提交之间指定文件的差异。

6. 查看分支之间的差异

bash 复制代码
git diff branch1 branch2

显示两个分支之间的差异。

7. 查看某次提交的更改

bash 复制代码
git diff commit1^!

这显示了commit1与其父提交之间的更改。

8. 限制diff输出的格式

bash 复制代码
git diff --stat

只显示每个文件的总结信息(如更改的行数和文件)。

9. 查看一定时间范围内的更改

bash 复制代码
git diff 'HEAD@{1 week ago}'

显示一周前与当前工作目录的差异。

相关推荐
ASEpochs43 分钟前
Vsocde中‘sh’不是内部或外部命令,也不是可运行的程序或批量处理文件--已解决
git·vscode·bash
coding消烦员1 小时前
在 Windows 内网搭建 Git 仓库:共享普通仓库 vs 中心 bare 仓库
windows·git
李@十一₂⁰2 小时前
git多分支管理
大数据·git·elasticsearch
爱写代码的派大星3 小时前
git 拉取和合并
git
Kp独立开发5 小时前
开源项目二次开发最佳实践:Fork + 分支隔离与同步
git·开源
Galaxy~5678 小时前
Git常见命令及用法
大数据·git·elasticsearch
MindCareers10 小时前
Beta Sprint Day 5-6: Android Development Improvement + UI Fixes
android·c++·git·sql·ui·visual studio·sprint
TTGGGFF10 小时前
报错解决:git clone git@github.com: Permission denied (publickey)权限拒绝问题
git·github
吻等离子11 小时前
Git版本管理:掌握Git Checkout 回溯备份与标签管理
git
小龙1 天前
[Git 报错解决]本地分支落后于远程分支(`non-fast-forward`)
大数据·git·elasticsearch·github