您的位置:首页 > 其它

5分钟 学会Git

2014-12-20 17:29 309 查看
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.git2.查看本地和远程的代码的区别:$ git statusOn branch developYour branch is up-to-date with 'origin/develop'.nothing to commit, working directory clean3.修改文件文件后,提交到服务器的三个步骤。3.1  指明要增加的文件,代码当前文件夹$git add . (git add 的意思是讲文件添加到暂存区 index)或$git add XXX.java3.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/develop5.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 --hardHEAD is now at 489a28b hello或者$git checkout -- a7. 注释里面的#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 path15.新增加的文件不能通过git commit -a命令添加到暂存区域,还得单独运行git add命令*** Commands ***  1: status  2: update   3:revert   4: add untracked  5: patch  6: diff   7:quit   8: help8.合并???我也还不知道怎么合并。。。。 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 的文件夹)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: