常用的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}'

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

相关推荐
abcnull14 分钟前
github中main与master,master无法合并到main
git·github
养意6 小时前
git提交代码和解决冲突修复bug
git·bug
码农黛兮_4619 小时前
Git 常用命令大全
git
一弓虽19 小时前
git 学习
git·学习
疯狂的沙粒1 天前
如何通过git命令查看项目连接的仓库地址?
大数据·git·elasticsearch
qq_254617771 天前
Gerrit+repo管理git仓库,如果本地有新分支不能执行repo sync来同步远程所有修改,会报错
git
π大星星️1 天前
Git分布式版本控制工具
分布式·git
kingbal1 天前
IDEA:配置 Git 需要完成 Git 路径设置、账号认证以及仓库关联三个主要步骤
git·idea
司徒小夜2 天前
处理git没做修改,但是文件显示变更的情况
git
m0_749317522 天前
vscode里如何用git
ide·git·vscode