Git 是最近这几年流行的源代码管理工具。
优点:分布式管理 ,去中心化,离线提交本地提交,可以自己代码Commit 到本地,而后在Push 合并,fork 别人的代码,然后自己可以闭门造车修改。
pull-request 工作流将 code review 强制纳入日常开发流程,而且足够简单
优点:难学,概念多,Eclipse 上面的egit 太二,提交默认针对是整个项目,而某个目录。
SVN:集中式管理
开玩笑的一句话:Git 能离线使用只是个传说,你仍然需要联网搜索该用哪个命令传什么参数。
Git 原理和概念:
1.git 暂存区(Index,各种修改文件都可以放入暂存区) git add 将文件内容存入blob 对象,git commit 将index 生成tree 对象
2.Git用blob对象来存储文件内容,用tree对象存储目录里的文件名。
前置条件:
1.配置SSH,SSH好处就是提供可以信任计算机的认证,而无需通过密码。简单来说,每次下载东西,你再也不用输入密码了。
2.已经安装Git 的命令行
1.从Git拖项目,如
$ git clone [email protected]:spring/spring.git
2.查看本地和远程的代码的区别:
$ git status
On branch develop
Your branch is up-to-date with 'origin/develop'.
nothing to commit, working directory clean
3.修改文件文件后,提交到服务器的三个步骤。
3.1 指明要增加的文件,代码当前文件夹
$git add .
(git add 的意思是讲文件添加到暂存区 index)
或
$git add XXX.java
3.2 commit 到本地,commit 到github之前必须要Commit 到本地。( -m 代码注释 ,引号“ ”是注释的内容)
$git commit -m "test it "
3.3上传到服务器
$git push
到此你已经成功把XXX.java 文件成功提交到服务器。
4.拖最新服务器的代码,改代码之前,最后先pull 一下,免得要慢慢合并
$git pull
5.本地Commit 了3个,领先服务器3个版本,但是只想提交一个版本。
$git reset /origin/develop
5.1单个文件覆盖
$git checkou -- 文件
然后再
5.1 git add .
5.2 git commit -m "test again"
5.3.git push
大功告成
6.要用远程服务的文件,全覆盖本地的文件,相当于(Replace All ),本地修改会全无,你再也找不到了。
如果有修改,你用了,是男人的不要哭了,你可以熬夜重敲一遍,颤抖吧骚年。
$ git reset origin/develop --hard
HEAD is now at 489a28b hello
或者
$git checkout -- a
7. 注释里面的#3,能和github 里面的issue 结合起来。
git commit -m “#3 “
8.查看日志
git log
9.查看分支
$git branch --all
# 默认只有master分支,所以会看到如下两个分支
# master[本地主分支] origin/master[远程主分支]
# 新克隆下来的代码默认master和origin/master是关联的,也就是他们的代码保持同
10.在分支上开发
git checkout dev # 切换到dev分支进行开发
# 开发代码之后,我们有两个选择
# 第一个:如果功能开发完成了,可以合并主分支
git checkout master # 切换到主分支
git merge dev # 把dev分支的更改和master合并
git push # 提交主分支代码远程
git checkout dev # 切换到dev远程分支
git push # 提交dev分支到远程
# 第二个:如果功能没有完成,可以直接推送
git push # 提交到dev远程分支
# 注意:在分支切换之前最好先commit全部的改变,除非你真的知道自己在做什
11.删除分支
git push origin :dev # 删除远程dev分支,危险命令哦
# 下面两条是删除本地分支
git checkout master # 切换到master分支
git branch -d dev # 删除本地dev分支
12.其它高级功能
git rebase
git rebase origin/dev # 将你的commits移到的末尾
13. 产看文件的修改
$ git diff pom.xml
14.git add -i
$ git add -i
staged unstaged path
15.新增加的文件不能通过git commit -a命令添加到暂存区域,还得单独运行git add命令
*** Commands ***
1: status 2: update 3: revert 4: add untracked
5: patch 6: diff 7: quit 8: help
8.合并???我也还不知道怎么合并。。。。
REF:
http://git-scm.com/book/en/v2
https://www.atlassian.com/git/tutorials/comparing-workflows
https://www.atlassian.com/git/tutorials/comparing-workflows/forking-workflow
http://www.zhihu.com/question/19946553
https://www.youtube.com/watch?v=4XpnKHJAok8
问题:
1.git 之前为什么要先add.
2.git 怎么对某个目录操作,而暂时先不管其它的。(SVN会在每个目录设置一个.svn 的文件夹)