美文网首页
Git知识简介

Git知识简介

作者: 枯木风 | 来源:发表于2018-12-02 23:08 被阅读0次

    介绍

        Git是一个开源的分布式版本控制系统,用以有效、高速的处理从很小到非常大的项目版本管理。git是个工具,在linux里面也就类似gcc这样的工具一样,是一个shell命令。

    Git与GitHub区别

    • Git是版本控制工具
    • Github是一个平台,提供给用户创建git仓储空间,保存(托管)用户的一些数据文档或者代码等。

    Git与CVS、SVN的区别

    • Git是分布式版本控制系统,代码提交是在本地的(如此速度就快),当然生成补丁(patch)然后push到远程服务器上是需要联网的
    • CVS、SVN是集中式版本控制系统,代码提交都是提交到远程服务器上
    • CVS、SVN这样的集中式版本控制系统,它的完整代码仓库(代码仓库不仅仅只包含了代码,还包含各个历史版本的信息等)在中心服务器上,一旦这个中心服务器挂了,也就是完整的代码仓库挂了</li>
    • Git没有中心服务器的概念,每一个git客户端(git节点)都含有一个完整的代码仓库(前提是你之前从远程git仓库fetch过代码)

    远程仓库、工作区、版本库和暂存区

    远程仓库

        就是在github或者在gitlab上的代码。可以用git pullgit push来进行本地仓库和远程仓库的同步操作

    工作区(Working Directory)

        从项目中取出某个版本的所有文件和目录,用以开始后续工作的叫做工作目录,也就是工作区

    版本库(Repository)

        工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
        Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD

    暂存区(Stage)

        暂存区就是版本库中的一个区域,具体参见上面的结构图

    工作区、版本库、暂存区之间的关系
    1. 使用git add把文件从工作区添加到版本库中的暂存区,git add命令可以多次用,或者使用git add file1 file2 ...
    2. 使用git commit提交代码,就是把暂存区的所有内容提交到当前分支
    3. 需要提交的文件修改通通放到暂存区(可能有多次的git add),然后,一次性提交暂存区的所有修改到当前分支(git commit)

    版本回退

        前提条件:已经执行git commit命令了,但是没有push到远程仓库,用以下命令可以回退
        其实这个回退就是将本地的HEAD指针移动到某个版本上而已,所以这个操作是非常快的。

    回退到上一个版本
    • 在Git中,用HEAD表示当前版本,也就是最新的提交3628164...882e1e0,上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100
    • 版本号没必要写全,前几位就可以了,Git会自动去找。当然也不能只写前一两位,因为Git可能会找到多个版本号,就无法确定是哪一个了
    $ git reset --hard HEAD^
    HEAD is now at ea34578 add distributed
    
    回退到未来的某个版本
    • 使用git log命令查看提交记录,找到需要回退版本的commit id
    • 如果在回退以后又想再次回到之前的版本,git reflog 可以查看所有分支的所有操作记录(包括commit和reset的操作),包括已经被删除的commit记录
    $ git reset --hard 3628164
    HEAD is now at 3628164 append GPL
    

    git log则不能查看已经删除了的commit记录

    总结
    • HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id
    • 穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本
    • 要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本

    git reset –-soft:回退到某个版本,只回退了commit的信息,不会恢复到index file一级。如果还要提交,直接commit即可
    git reset -–hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容,撤销的commit中所包含的更改被冲掉

    撤销修改

    含义

        命令git checkout -- file意思就是,把file文件在工作区的修改全部撤销,这里有两种情况:

    • 一种是file自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;
    • 一种是file已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
      总之,就是让这个文件回到最近一次git commit或git add时的状态。
    场景
    • 场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file
    • 场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了场景1,第二步按场景1操作</li>
    • 场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,版本回退一节,不过前提是没有推送到远程库

    git stash

        场景:当你接到一个修复一个代号101的bug的任务时,你想创建一个分支issue-101来修复它,但是,当前正在dev上进行的工作还没有提交,Git还提供了一个stash功能,可以把当前工作现场“储藏”起来,等以后恢复现场后继续工作

    git stash list

        查看暂存区的所有暂存修改记录

    $ git stash list
    stash@{0}: WIP on dev: 6224937 add merge
    
    git stash apply stash@{X}

        取出相应的暂存

    git stash drop stash@{X}

        将记录列表中取出的对应暂存记录删除

    git stash pop(推荐)

        取出最近一次暂存并删除记录列表中对应记录

    分支管理

    命令 含义
    git branch 查看分支
    git branch <name> 创建分支
    git checkout <name> 切换分支
    git checkout -b <name> 创建+切换分支
    git merge <name> 合并某分支到当前分支
    git branch -d <name> 删除分支
    Bug分支

        在Git中,由于分支是如此的强大,所以,每个bug都可以通过一个新的临时分支来修复,修复后,合并分支,然后将临时分支删除。

    Feature分支

        添加一个新功能时,你肯定不希望因为一些实验性质的代码,把主分支搞乱了,所以,每添加一个新功能,最好新建一个feature分支,在上面开发,完成后,合并,最后,删除该feature分支。

    相关文章

      网友评论

          本文标题:Git知识简介

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