一、Git分布式版本控制系统
git是目前世界上最先进的分布式版本控制系统,git包含工作区,暂存区,本地仓库和远程仓库几个概念。工作区就是指本地文件编辑区,暂存区指新提交的文件可以放到暂存区不提交,本地仓库和远程仓库就是管理代码版本。借用以下一张图,比较清晰的说明git的基本使用语法。理解此概念对于使用git有较大的作用。
Workspace:工作区
Index / Stage:暂存区
Repository:仓库区(或本地仓库)
Remote:远程仓库
关于SVN和Git的区别:
SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而干活的时候,用的都是自己的电脑,所以首先要从中央服务器哪里得到最新的版本,然后干活,干完后,需要把自己做完的活推送到中央服务器。集中式版本控制系统是必须联网才能工作,如果在局域网还可以,带宽够大,速度够快,如果在互联网下,如果网速慢的话,就纳闷了。
Git是分布式版本控制系统,那么它就没有中央服务器的,每个人的电脑就是一个完整的版本库,这样,工作的时候就不需要联网了,因为版本都是在自己的电脑上。既然每个人的电脑都有一个完整的版本库,那多个人如何协作呢?比如说自己在电脑上改了文件A,其他人也在电脑上改了文件A,这时,你们两之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。
二、Git基础命令
2.1 拉取远程仓库
使用git clone
,
例:git clone https://github.com/Tencent/wepy.git
2.2 查看工作区有哪些更改
使用git status
例:建立新文件test.txt
后
例:修改已有文件test.txt
后
2.3 将工作区更改的文件提交到暂存区
使用git add
使用git add .
将所有修改文件添加到暂存区
2.4 将暂存区更改的文件提交到本地仓库
使用git commit
例:将test.txt
提交到本地仓库
使用git commit
后需要输入提交备注,修改信息,如我在这里写的是add test.txt
使用git commit -m
直接写提交备注
2.5 还原工作区的更改
使用git checkout
还原所有或者指定文件名
2.6 还原暂存区的更改(使其回到工作区)
使用git reset
还原所有或者指定文件名
2.7 将本地分支更新推送到远程主机
使用git push
例:git push origin master
将本地的master分支推送到origin主机的master分支。如果后者不存在,则会被新建。
2.8 从远程获取最新代码并合并本地的版本
使用git pull
相当于git fetch
+git merge
2.9 从远程获取代码库,但是不会合并到本地版本
使用git fetch
该命令执行完后需要执行git merge
远程分支到你所在的分支
三、Git分支相关命令
3.1 查看当前所在分支
使用git branch
使用git branch
+分支名可以创建分支,使用git checkout
+分支名切换分支
使用git checkout –b
+分支名可以直接创建并切换分支
3.2 将指定分支合并到当前分支
使用git merge
3.3 删除指定分支
使用git branch –d
+分支名
四、特殊命令
4.1 合并多个commit
使用git rebase -i
+commit-id会合并此次提交之后所有的提交为一个提交, 注意此次commit-id的提交不会包含在内。
使用前:
使用后:
4.2 指定的提交(commit)应用于其他分支
使用git cherry-pick
+分支名
4.3 将指定提交(commit)应用于当前分支
使用git cherry-pick
+commit_id指定某一个提交
使用git cherry-pick
+commit_id1 commit_id2 指定某写提交
使用git cherry-pick
+commit_id1..commit_id2 指定从commit_id1到commit_id2但不包括commit_id1的提交
使用git cherry-pick
+commit_id1^..commit_id2 指定从commit_id1到commit_id2的所有提交
4.4 临时保存和回复修改
使用git stash
4.4.1git stash save "save message"
: 执行存储时,添加备注,方便查找,只有git stash 也要可以的,但查找时不方便识别。
4.4.2git stash list
:查看stash了哪些存储
4.4.3git stash show
:显示做了哪些改动,默认show第一个存储,如果要显示其他存贮,后面加stash@{$num},比如第二个 git stash show stash@{1}
4.4.4git stash show -p
: 显示第一个存储的改动,如果想显示其他存存储,命令:git stash show stash@{$num} -p ,比如第二个:git stash show stash@{1} -p
4.4.5git stash apply
:应用某个存储,但不会把存储从存储列表中删除,默认使用第一个存储,即stash@{0},如果要使用其他个,git stash apply stash@{$num} , 比如第二个:git stash apply stash@{1}
4.4.6git stash pop
:命令恢复之前缓存的工作目录,将缓存堆栈中的对应stash删除,并将对应修改应用到当前的工作目录下,默认为第一个stash,即stash@{0},如果要应用并删除其他stash,命令:git stash pop stash@{$num} ,比如应用并删除第二个:git stash pop stash@{1}
4.4.7git stash drop stash@{\$num}
:丢弃stash@{$num}存储,从列表中删除这个存储
4.4.8git stash clear
:删除所有缓存的stash
4.5 比较文件之间的不同
使用git diff
查看 workspace(工作区) 与 index(暂存区) 的差别
使用git diff --cached
查看 index(暂存区) 与 local repositorty(本地仓库) 的差别
使用git diff HEAD
查看 workspace(工作区) 和local repositorty(本地仓库)的差别
转载文章
Git常用命令介绍
Git使用教程:最详细、最傻瓜、最浅显、真正手把手教
git cherry-pick 教程