git diff 比较差异


说明

以下命令可以不指定 <filename>,表示对全部文件操作。 命令涉及和 Git本地仓库对比的,均可指定 commit 的版本。

  • HEAD 最近一次 commit
  • HEAD^ 上次提交
  • HEAD~100 上100次提交
  • commit版本是每次提交产生的哈希值

工作区 vs 暂存区

查看文件在工作目录与暂存区的差别。如果还没 add 进暂存区,则查看文件自身修改前后的差别。也可查看和另一分支的区别。

git diff <filename>

暂存区 vs 本地仓库

查看已经 add 进暂存区但是尚未 commit 的内容同最新一次 commit 时的内容的差异。 也可以指定仓库版本

git diff --cached <filename>

工作区 vs 本地仓库

git diff <commit> <filename>

查看工作区同本地仓库指定 commit 的内容的差异。 <commit>=HEAD 时:查看工作目录同最近一次 commit 的内容的差异。

git diff HEAD^ <文件名>

则显示上一次提交之前工作目录与git仓库之间的差异。所以我们在git pull后,可以通过git diff HEAD^来查看拉下来的文件有那些具体的修改。

Git本地仓库 vs Git本地仓库

Git仓库任意两次 commit 之间的差别。

git diff <commit> <commit>

分支 vs 分支

#显示出所有有差异的文件的详细差异
git diff <branchA> <branchB>

#比较当前分支时可省略
git diff <目标分支>

# 比较A分支中有B分支没有的提交记录
git log branchA ^branchB    

#显示出branch1和branch2中差异的部分
git diff branch1 branch2 --stat

#生成一个.diff文件记录所有差异
git diff [branchA] [branchB] >>d:/diff/exportname.diff


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM