2.git学习系列之git基本操作和分支管理

一、git基本操作

1、git的结构

  • git工作结构分为三个区域:工作区、临时存储区、本地库,三者之间的关系如图所示(写代码是在工作区完成-->add-->临时存储区stage-->commit-->本地仓库)


    git结构

2、git基本命令

(1)创建本地版本库

git init命令是初始化本地仓库

  • 先打开Git Bash命令行界面:
Administrator@BF-20180604CDXI MINGW64 ~/Desktop
$ mkdir demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop
$ cd demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo
$ pwd
/c/Users/Administrator/Desktop/demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo
$ git init//初始化本地仓库
Initialized empty Git repository in C:/Users/Administrator/Desktop/demo/.git/
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ ll -a//查看本地仓库目录下文件,.git/为隐藏文件
total 20
drwxr-xr-x 1 Administrator 197121 0 九月 15 23:47 ./
drwxr-xr-x 1 Administrator 197121 0 九月 15 23:47 ../
drwxr-xr-x 1 Administrator 197121 0 九月 15 23:47 .git/

(2)提交文件到本地仓库

git add把写好的代码从工作区提交到临时存储区stage
git commit 把临时区的代码提交到本地仓库
git status 查看状态(工作区,临时区的状态)
git log查看历史提交版本
git log --oneline整洁的查看历史提交版本
git reflog可以查看所有分支的所有操作记录

Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ vim demo//1、在工作区中创建一个文件
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git status//2、查看状态(此刻还在工作区中)
On branch master
No commits yet
Untracked files:
  (use "git add <file>..." to include in what will be committed)
        demo
nothing added to commit but untracked files present (use "git add" to track)
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git add ..//3、从工作区添加到临时区
warning: LF will be replaced by CRLF in demo.
The file will have its original line endings in your working directory.
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git status//4.查看状态(此时在临时区了)
On branch master
No commits yet
Changes to be committed:
  (use "git rm --cached <file>..." to unstage)
        new file:   demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git log//5、查看历史提交记录(此时没有历史提交记录)
fatal: your current branch 'master' does not have any commits yet
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git commit -m "demo"//6、提交代码到本地仓库
[master (root-commit) fed3895] demo
 1 file changed, 1 insertion(+)
 create mode 100644 demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git status//7、查看状态(此时在本地仓库了)
On branch master
nothing to commit, working tree clean
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git log//8、查看历史提交记录(此时有一条记录commitid=fed3895exxx)
commit fed3895eef27f31ec8a0b0642223e5742bb22d02 (HEAD -> master)
Author: qiuzhangwei <2608442616@qq.com>
Date:   Sun Sep 16 00:02:33 2018 +0800
    demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git reflog//9、整洁的查看历史
fed3895 (HEAD -> master) HEAD@{0}: commit (initial): demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$

(3)回退修改(回退modified文件)

  • 修改后,还没有add到临时区

git checkout -- 文件(放弃改变在工作区)

  • add到临时区但是没有commit到本地仓库

先git reset HEAD 文件(从暂存区回到工作区)
然后git checkout -- 文件(放弃改变在工作区)

  • 已近commit到了本地仓库

git reset --hard 版本号或HEAD^或HEAD~n(本地仓库回退到之前的版本)

(4)其他基本操作

git status 状态查看(工作区、暂存区状态)
git log查看历史记录
git reflog查看简介的历史记录
git diff 比较文件差异(将工作区中的文件和暂存区进行比较)

3.分支管理

(1)概念

在版本控制过程中,使用多条线同时推进多个任务。

(2)分支好处

  • 同时并行推进多个功能开发,提高开发效率
  • 各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可

(3)分支基本操作

git branch [分支名]创建分支
git branch -v查看分支
git checkout [分支名]切换分支
git branch -d [分支名]删除未提交的分支
git branch -D [分支名]强制删除一个已经提交了的分支

Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git branch -v//查看当前分支
* master f302b1c sdf
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git branch dev//创建dev分支
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git checkout dev//切换到dev分支
Switched to branch 'dev'
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (dev)
$ git branch -v//查看当前分支
* dev    f302b1c sdf
  master f302b1c sdf

(4)使用merge分支合并


merge流程图

第一步:切换到接受修改的分支(被合并,增加新内容)上
git checkout [被合并分支名]
第二步:执行 merge 命令
git merge [有新内容分支名]
第三步:解决冲突如果有冲突的话
-->打开冲突文件
-->把文件修改到满意的程度,保存退出
-->git add [文件名]
-->git commit -m "日志信息"

案例:

在master分支上
1、vim a.txt
a1
2、git add和git commit提交到本地仓库
切换到dev分支
3、git checkout dev
4、vim a.txt
a2
5、git add和git commit提交到本地仓库
切换回master分支进行合并
6、git merge dev--产生冲突
7、vim a.txt进行冲突解决
----------------------------当前分支内容--------------------------
<<<<<<< HEAD
a1
=======
----------------------------需要合并的分支内容--------------------------
a2
>>>>>>> dev
8、解决冲突后vim a.txt
a1
a2
9、进行git add 和git commit就完成了分支的合并

(5)使用rebase合并分支

第一步:切换到接受修改的分支(被合并,增加新内容)上
git checkout [被合并分支名]比如develop
第二步:执行 rebase命令
git rebase[有新内容分支名]比如master
第三步:解决冲突如果有冲突的话
-->打开冲突文件
-->把文件修改到满意的程度,保存退出
-->git add [文件名]
-->git rebase --continue
-->推到远程仓库然后进行取出冲突
-->如果要放弃这次合并,使用git rebase --abort
第四步:快进式合并一下,移动 master 的指针指向最新的提交
git merge master develop

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

推荐阅读更多精彩内容

  • Git是目前最流行的版本管理系统,也是最先进的分布式版本控制系统(distributed version cont...
    pro648阅读 5,690评论 1 17
  • 《了凡四训》是明代著名思想家袁了凡给自己儿子写的告诫书。全书共四个章节,包含了儒家、佛家、道家三家学说,并被后世誉...
    金蜘蛛_bb64阅读 869评论 0 2
  • 此刻外面下雨了,我呢? 在听外面的雷雨声。 是不是这场雨过后青岛就入夏了? 早上暖奶奶来接我们,我抱着小二,暖跟着...
    小猪天堂阅读 305评论 0 1
  • 勇于表达自己的想法,同时也要考虑别人的想法,不要盲目追随权威。
    mochow阅读 255评论 0 1
  • 刚刚看微博的一篇文章,最后提到了简书。听说是个作为新手码字的好去处,先冒个泡……太晚了,应该是快早安了,其...
    愛吃辣椒的驢子阅读 134评论 0 0