Git基础教程

一、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 教程

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,393评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,790评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,391评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,703评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,613评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,003评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,507评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,158评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,300评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,256评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,274评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,984评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,569评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,662评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,899评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,268评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,840评论 2 339

推荐阅读更多精彩内容

  • 一、Git简介 首先简单介绍一下Git。Git 是一个开源的分布式版本控制系统。那与传统的集中式,比如cvs,sv...
    课间指针阅读 311评论 1 1
  • 命令说明 <>内的内容为必填项 []内的内容为选填项 file代指具体的文件路径 message代指具体的说明内容...
    周老一员阅读 107评论 0 0
  • 简介 Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 Git 与常用的版本控制工具 ...
    闽越布衣阅读 2,725评论 0 18
  • 一、Git简介 用一句话来说: Git是目前世界上最先进的分布式版本控制系统(没有之一) Git有什么特点:简单的...
    天痕丶阅读 207评论 0 0
  • 简介 Git Git是开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 Linus Torvald...
    啤酒找尿布阅读 462评论 0 0