Git常用命令总结:http://www.cnblogs.com/mengdd/p/4153773.html
git rebase 使用 : http://blog.csdn.net/witsmakemen/article/details/22661605
git fetch和git pull之间的区别 http://blog.csdn.net/a19881029/article/details/42245955
使用原理视角看Git http://www.cnblogs.com/Coding-net/p/5577485.html
想看到最近一次提交所有更改过的文件:对应命令 git log -n 1 --stat
想看到最近一次提交所有更改的细节:对应命令 git log -n 1 -p
服务器强制覆盖本地
git fetch --all
git reset --hard origin/master
比较提交结果:
1.比较working directory 和 index:
git diff (or git diff --stat)
2.比较index 和 repository:
git diff --cached
3.比较working directory 和 repository:
git diff HEAD
4.比较远程分支文件 和 working directory:
git diff remote/remtoteBranch workingDirectoryFilename
(例如: git diff origin/master src/ 或 git diff origin/master src/main.java)
git diff origin/分支名 HEAD
5.比较两次已提交版本:
git diff SHA1 SHA2
6.比较上次提交commit和上上次提交
git diff HEAD^ HEAD
git reset和git checkout:
git reset
git reset --hard
1.替换引用的指向.引用指向新的提交ID;
2.替换暂存区.替换后,暂存区的内容和引用指向的目录树一致;
3.替换工作区.替换后,工作区的内容变得和暂存区一致,也和HEAD所指向的目录树内容相同.
git reset --soft
替换引用的指向.引用指向新的提交ID.
即只更改引用的指向,不该编暂存区和工作区.
git reset --mixed
1.替换引用的指向.引用指向新的提交ID;
2.替换暂存区.替换后,暂存区的内容和引用指向的目录树一致;
即更改引用的指向及重置暂存区,但是工作区不变.
实例:
git reset
仅用HEAD指向的目录树重置暂存区,工作区不受影响,相当于将之前用git add命令更新到暂存区的内容撤出暂存区.引用也未改变,因为引用重置到HEAD相当于没有重置.
git reset HEAD
同上
git reset -- filename
仅将文件filename的改动撤出暂存区,暂存区中其他文件不该变.相当于git add filename的反向操作.
git reset HEAD filename
同上
git reset --soft HEAD^
工作区和暂存区不改变,但是引用向前回退一次.当对最新提交的提交说明或提交不满意更改时,撤销最新的提交一遍重新提交.
git reset HEAD^
工作区不变,但是暂存区会回退到上一次提交之前,引用也会回退一次.
git reset --mixed HEAD^
同上
git reset --hard HEAD^
彻底撤销最近的提交.引用回退到前一次,而且工作区和暂存区都会回退到上一次提交的状态.自上一次以来的提交全部丢失.
git checkout
git checkout
1.
2.因此重置一般用于重置暂存区(除非使用--hard,否则不重置工作区),而检出命令主要是覆盖工作区(如果
3.该命令不会改变HEAD的头指针,主要用于指定版本文件覆盖工作区中对应的文件.如果省略
git checkout
1.会改变HEAD头指针.之所以后面的参数写作
2.如果省略
实例:
git checkout branch
检出branch分支,更新HEAD以指向branch分支,以及用branch指向的树更新暂存区和工作区.
git checkout
汇总显示工作区,暂存区与HEAD的差异
git checkout HEAD
同上
git checkout -- filename
用暂存区中的filename文件来覆盖工作区中的filename文件.相当于取消自上次执行git add filename以来(如果执行过)的本地修改
git checkout branch -- filename
维持HEAD的指向不变.用branch所指向的提交中的filename替换暂存区和工作区中相应的文件.会将暂存区和工作区中的filename直接覆盖
git checkout -- .或者git checkout .
会取消本地所有修改,相当于用暂存区的所有文件直接覆盖本地文件.