http://www.cnblogs.com/schaepher/p/5561193.html
原文链接:Git和Github简单教程
网络上关于Git和GitHub的教程不少,但是这些教程有的命令太少不够用,有的命令太多,使得初期学习的时候需要额外花不少时间在一些当前用不到的命令上。
这篇文章主要的目标是用较少的时间学习Git和GitHub的基本使用。在足够一般使用的前提下,尽量减少命令。
如果需要其他命令,到时候再去其他地方了解就行了。
目录:
- 零、Git是什么
- 一、Git的主要功能:版本控制
- 二、概览
- 三、Git for Windows软件安装
- 四、本地Git的使用
- 五、Github与Git的关联
- 六、团队合作开发
- 七、Github的其他介绍
- 八、一些可能碰到的问题
零、Git是什么
我才不告诉你嘞
一、Git的主要功能:版本控制
- 版本:
想想你平时用的软件,在软件升级之后,你用的就是新版本的软件。你应该见过这样的版本号:v2.0
或者1511
(表示发布时为15年11月),如下图:
那么如果你修改并保存了一个文件,从版本管理的角度来说,你得到的是这个文件的新版本。
可是很多情况下,这种修改是不可逆的。你修改完之后,无法回到你修改前的样子。为了避免这种情况,有的人会把新版本的内容保存到一个新的文件里面。
比如在一个名为“毕业论文”的文件夹内,他有以下文件:
就在这时,他女朋友发了一份毕业论文_完成2.doc
,这是女朋友帮他改的一篇论文。可是已经经过那么多的修改,又不知道对方改了哪些,怎么合并呢?看来只好开始了繁重的对照以及修改的工作……
更加实际的例子是程序员写程序的时候:
这时候你需要一款软件帮你管理版本,它就是Git。
- 控制:
你可以用Git来对这些不同的版本进行控制。还可以很方便地查看两个不同版本之间的不同之处。
——使用Git,你只保存最新的一份文件就可以了。
——那我以前的文件怎么办?
——可以用Git帮你把文件回退到你想要的版本。
——如果回去了,那我的最新版本呢?
——还可以还原。
二、概览
所有命令前都要加 git
,如表中的init
是指 git init
。
点击命令可直接跳转至本文第一次使用的地方。
以下命令都在命令行里执行。
1.个人本地使用
行为 | 命令 | 备注 |
---|---|---|
初始化 | init | 在本地的当前目录里初始化git仓库 |
clone 地址 | 从网络上某个地址拷贝仓库(repository)到本地 | |
查看当前状态 | status | 查看当前仓库的状态。碰到问题不知道怎么办的时候,可以通过看它给出的提示来解决问题 |
查看不同 | diff | 查看当前状态和最新的commit之间不同的地方 |
diff 版本号1 版本号2 | 查看两个指定的版本之间不同的地方。这里的版本号指的是commit的hash值 | |
添加文件 | add -A | 这算是相当通用的了。在commit之前要先add |
撤回stage的东西 | checkout -- . | 这里用小数点表示撤回所有修改,在-- 的前后都有空格 |
提交 | commit -m "提交信息" | 提交信息最好能体现更改了什么 |
删除未tracked | clean -xf | 删除当前目录下所有没有track过的文件。不管它是否是.gitignore文件里面指定的文件夹和文件 |
查看提交记录 | log | 查看当前版本及之前的commit记录 |
reflog | HEAD的变更记录 | |
版本回退 | reset --hard 版本号 | 回退到指定版本号的版本,该版本之后的修改都被删除。同时也是通过这个命令回到最新版本。需要reflog配合 |
2.个人使用远程仓库
行为 | 命令 | 备注 |
---|---|---|
设置用户名 | config --global user.name "你的用户名" | |
设置邮箱 | config --global user.email "你的邮箱" | |
生成ssh key | ssh-keygen -t rsa -C "你的邮箱" | 这条命令前面不用加git |
添加远程仓库 | remote add origin 你复制的地址 | 设置origin |
上传并指定默认 | push -u origin master | 指定origin为默认主机,以后push默认上传到origin上 |
提交到远程仓库 | push | 将当前分支增加的commit提交到远程仓库 |
从远程仓库同步 | pull | 在本地版本低于远程仓库版本的时候,获取远程仓库的commit |
可以用一张图直观地看出以上主要的命令对仓库的影响。
图片引用自:Git introduction for CVS/SVN/TFS users
图片引用自:工作区和暂存区 - 廖雪峰的官方网站 (做了点修改)
对照查看两张图:
- workspace 即工作区,逻辑上是本地计算机,还没添加到repository的状态;
- staging 即版本库中的stage,是暂存区。修改已经添加进repository,但还没有作为commit提交,类似于缓存;
- Local repository 即版本库中master那个地方。到这一步才算是成功生成一个新版本;
- Remote repository 则是远程仓库。用来将本地仓库上传到网络,可以用于备份、共享、合作。本文将使用Github作为远程仓库的例子。