高大上的Git

作者: 朋友喜欢叫我春哥 | 来源:发表于2017-12-31 12:50 被阅读4次

最近学习Git感觉真是是高大上,用简易的方式解决了复杂的版本管理问题。如果要深入介绍Git,其实够一本书了,所以我根据最近学习情况,总结一下Git的基本知识点吧。


一、Git是什么?

Git是目前非常流行的分布式版本管理系统。

开发Git最初目的是为更好地管理Linux内核开发而设计。

  • 什么是版本管理?

    简单说就是记录你的修改。比如你修改一个文档,今天你修改了最后一段文字,过了一周又修改了最后一段文字,但是你后悔了,想恢复到一周前的版本,但是完全记不得之前的内容,怎么办呢?那这个时候就需要版本管理了,版本管理可以记录你的每次修改,这样你就可以回到过去。

  • 为什么使用Git?

    有的人会说,世界这么多版本管理系统,Git有什么好吗?主要有四点:

    • 速度快,操作简单
    • 分布式管理
    • 极其优秀的分支管理
    • 开源项目

二、 Git的安装

  • Mac下的安装

    Mac下安装我推荐使用homebrew,具体方法请参考homebrew的文档

  • Windows下的安装

    在Windows下安装Git,其实和安装其他软件没什么区别,去Git官网下载安装软件即可


三、Git初次体验

安装完后,进入一个新建的文件夹里,我们来体验一下Git的使用

  • 初始化仓库

    // 在当前目录新建一个Git代码库
    git init
    
  • 添加文件

    // 新建一个 a.txt 文件
    touch a.txt
    
    //  添加指定文件到暂存区
    git add a.txt
    
  • 提交文件

    // 提交暂存区到本地仓库区
    git commit -m '添加文件 a.txt'
    

这样你就记录下添加a.txt文件的修改

四、Git的基本使用

4.1 Git的基本概念

  • 工作区 (Working Directory)

    工作区就是你本机操作文件的地方

  • 暂存区 (Stage)

    当你初始化仓库时,你会发现工作区里多了个.git的文件夹,这就是本地仓库。这里有个很重要的区域就是暂存区,当你执行git add的时候,其实就是把文件修改添加到暂存区。

  • 本地仓库 (History)

    .git文件夹就是本地仓库,里面还有一个重要区域就是默认的master分支,当你执行git commit的时候,其实就是把暂存区的所有内容添加到当前分支上。

4.2 添加文件并提交

  • git add

    添加修改文件到暂存区

  • git status

    查看工作区的变化

  • git commit

    把暂存区所有内容提交到当前分支上

  • git pull

    取回远程仓库的变化

  • git push origin master

    上传本地master分支到远程仓库

4.3 版本回退

现代的人总想回到过去,可是时间是回不去的,但是Git可以实现你的愿望。

首先你要知道你想回到哪个版本,通过git log查看当前分支提交记录,
HEAD指向当前分支master,而master指向提交,也就是下面的commit_id (aa81633220d368b5f1...)

git log

commit aa81633220d368b5f1bc0677e676e2a118ab188e (HEAD -> master)
Author: JACK <shizhengchun2015@gmail.com>
Date:   Sun Dec 31 11:28:44 2017 +0800

    添加 b.txt

commit 91ff12ff6685a7316cecf83c85bbcc96a8d63e39
Author: JACK <shizhengchun2015@gmail.com>
Date:   Sun Dec 31 11:24:25 2017 +0800

    添加 a.txt

其次就是让我们回到过去,通过git reset --hard commit_id

git reset --hard 91ff12ff668
HEAD is now at 91ff12f 添加 a.txt

// 查看当前文件夹,发现已经回到添加a.txt的状态了
ls
a.txt

// 再次查看当前提交历史
git log

commit 91ff12ff6685a7316cecf83c85bbcc96a8d63e39 (HEAD -> master)
Author: JACK <shizhengchun2015@gmail.com>
Date:   Sun Dec 31 11:24:25 2017 +0800

    添加 a.txt

这个时候有人发现,那我还能回到添加 b.txt 文件的状态吗?恩,Git无所不能
想要回到未来,通过查看命令历史git reflog,我们就找到添加 b.txt 的commit_id,这样我就可以回到未来了

git reflog

91ff12f (HEAD -> master) HEAD@{0}: reset: moving to 91ff12ff668
aa81633 HEAD@{1}: commit: 添加 b.txt
91ff12f (HEAD -> master) HEAD@{2}: commit (initial): 添加 a.txt


git reset --hard aa81633
HEAD is now at aa81633 添加 b.txt

// 此时文件夹有了b.txt 我们成功回到未来
ls
a.txt b.txt


总结一下:

  • HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id。

  • 用git log可以查看提交历史,以便确定要回退到哪个版本。

  • 用git reflog查看命令历史,以便确定要回到未来的哪个版本。

五、Git的高级使用

5.1 本地新建Git项目并推送远程空仓库

  • 本地初始化Git项目库

    git init

  • 远程新建空仓库,(注意空仓库就是什么都没有)

    到GitHub新建仓库就行,新建成功就是这个样子

  • 关联本地仓库和远程空仓库

    // origin后面是你自己仓库的地址,别搞错了
    
    git remote add origin git@server-name:path/repo-name.git
    
  • 推送本地仓库到远程

    关联后,使用命令git push -u origin master第一次推送master分支的所有内容

5.2 分支管理

Git还有一个优势就是分支设计非常优秀,之前说过HEAD是指向分支的,当你初始化仓库时会默认产生master分支,所以默认HEAD是指向maser分支的。

其实切换分支的本质就是改变HEAD的指向,工作区什么都没有变。

新建一个分支dev,其实就是新建一个指针dev,并且指向和master相同的提交,同时让HEAD指向dev

// 新建分支dev
git branch dev

// 切换到分支dev
git checkout dev

----------------
// 其实可以一步到位,加参数-b就可以
git checkout -b dev

那现在工作区改变文件,提交文件就是在dev上面了,假如新提交一个commit,那么dev指针向前一步,但maser不变

OK,那我们现在来合并分支,其实原理就是把master指向dev当前的提交

// 首先切换到master分支
git checkout master

// 查看分支,带`*`的符合就是当前分支

git branch

// 把dev分支合并到master分支上

git merge dev

dev的分支使命已经完成了,那我们那删除dev分支,其实删除分支就是删除dev指针而已。

git branch -d dev

Git上面操作分支就是这样简单有效

总结一下:

  • 查看分支:git branch

  • 创建分支:git branch <name>

  • 切换分支:git checkout <name>

  • 创建+切换分支:git checkout -b <name>

  • 合并某分支到当前分支:git merge <name>

  • 删除分支:git branch -d <name>


其实Git还有很多命令,这些其实只是很小的一部分,但是我觉得掌握Git的基本概念后,其实遇到问题,其实可以搜索Git来学习。

才疏学浅,欢迎指导批评


参考链接

相关文章

  • 高大上的Git

    前言 虽说用了git 一段时间了,但是却没有深入了解过,今天随着廖雪峰大大的git教程来学习一波,顺便总结一下,方...

  • 高大上的Git

    最近学习Git感觉真是是高大上,用简易的方式解决了复杂的版本管理问题。如果要深入介绍Git,其实够一本书了,所以我...

  • git常用命令

    很多初学者以为 git 很高大上,其实不然。Git, 英文意思是:傻瓜。显然,git实际上就是个傻瓜式的版本控制软...

  • git 命令列表

    废话:Git,是分布式版本控制系统,在多人开发的模式下,相信很多人都在用高大上的git,git是目前版本控制系统中...

  • 高大上?

    LOFTER上有个『我用VSCO修片』,就是這个⋯

  • 高大上

    忍不住想起小时候的我,是如何年纪轻轻懂得说话高大上的。初一语文课,老师问看过骆驼祥子的举手。我和另外一个女生举手了...

  • 高大上

    我大襄阳现在真的是越来越高大上了啊! 你看:应急指挥、应急供水、应急医疗救护、应急灭火器、应急厕所、应急停车场、应...

  • 高大上

    坐在兰州开往定西的高铁上。 听前面一女一男聊天。 男:昨晚上你那个项目谈得怎么样? 女:差不多了。小项目,就一个亿...

  • 高大上

    好友说,龙颜惧内,单位里都出了名,我不信! 这天,龙颜到家刚开门,媳妇手持锅铲门前候着,很严肃的说到:“干什么去了...

  • 高大上

    香沐源,人家卖的就是高大上。以后再也不进去了!!!还不如52那块卖披萨饼那块儿呢。 还不如爱妮儿呢。 想吃点心,啥...

网友评论

    本文标题:高大上的Git

    本文链接:https://www.haomeiwen.com/subject/bmqogxtx.html