赞
踩
git diff 用来比较文件之间的不同,其基本用法如下。
git diff:显示工作目录(working tree)与索引区(即暂存区快照,index,就是git add过的)之间的文件变更,即显示未被add的文件变更。
git diff --cached 或 git diff --staged:显示索引区和最后一次commit(HEAD)之间的文件更改,即显示已add但还未commit的文件变更。也即用"git commit"(不带-a)将被提交的文件变更。
git diff HEAD:显示工作目录与最后一次commit之间的文件变更,即显示所有未commit(包括未add和add两类)的文件变更。也即用"git commit -a”将被提交的文件变更。
git diff <分支名1> <分支名2> :比较两个分支上最后 commit 的内容的差别。比如,先git fetch下,然后比较远程的master与当前分支已经commit的内容差别:git diff origin/master feature/20170831_1214776_xiufu_1。此时是以origin/master分支为基础进行比较的,若把xiufu分支写在前面,则是以xiufu分支为基础进行比较的。 也可写作:git diff <分支名1>…<分支名2>
要查看有哪些文件发生了变化,可以加上–stat参数:
git diff origin/master feature/20170502_806526_dianshang_1 --stat
根据–stat的结果得到存在差异的文件列表,然后可用git diff 进一步查看该文件在两个分支中的差异:
git diff origin/master feature/20161114_263258_marketing_1 biz/src/main/java/com/sports/gerrard/biz/service/MarketingActivityService.java
1.git diff用来比较文件之间的不同,其基本用法如下:
(1)git diff:当工作区有改动,临时区为空,diff的对比是“工作区与最后一次commit提交的仓库的共同文件”;当工作区有改动,临时区不为空,diff对比的是“工作区与暂存区的共同文件”。
(2)git diff --cached 或 git diff --staged:显示暂存区(已add但未commit文件)和最后一次commit(HEAD)之间的所有不相同文件的增删改(git diff --cached和git diff –staged相同作用)
(3)git diff HEAD:显示工作目录(已track但未add文件)和暂存区(已add但未commit文件)与最后一次commit之间的的所有不相同文件的增删改。
(3.1)git diff HEAD~X或git diff HEAD^^…(后面有X个符号,X为正整数):可以查看最近一次提交的版本与往过去时间线前数X个的版本之间的所有同(3)中定义文件之间的增删改。
(4)git diff <分支名1> <分支名2> :比较两个分支上最后 commit 的内容的差别
(4.1) git diff branch1 branch2 --stat 显示出所有有差异的文件(不详细,没有对比内容)
(4.2) git diff branch1 branch2 显示出所有有差异的文件的详细差异(更详细)
(4.3) git diff branch1 branch2 具体文件路径 显示指定文件的详细差异(对比内容)
我们有2个分支:master、dev(dev为develop的缩写,应是开发新功能的Feature分支),查看这两个 branch 的区别,除了上面(abc)还有以下几种方式:
(4.4) git log dev ^master 查看 dev中log有的commit,而 master中log没有的commit
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。