5分钟 学会Git

来源:互联网 发布:mmorpg手游推荐知乎 编辑:程序博客网 时间:2024/04/27 18:28

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 git@github.com: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 的文件夹)


0 0