美文网首页
git的使用

git的使用

作者: kim_jin | 来源:发表于2019-03-28 09:12 被阅读0次

我们主分支上面提交代码,我们使用git commit的命令进行提交,很简单,我在进行详细的描述。

分支

创建分支
我们通过实际操作看一下分支是什么样子的,比如说我们先要创建一个名字为newImage的分支。创建分支前:

创建分支前

使用命令 git branch newImage之后

创建分支后

在新的分支上面提交内容
当我们向新的分支上面提交一些新的东西,如果我们直接执行git commit

直接执行git commit 命令

我们会发现master分支前进了,但是newImage分支还是待在原地。我们仔细看一下上图,我们发现现在在master上面有一个星号,这表示的是我们现在在master分支上面。所以我们正确的操作是,先切换到新分支上面,然后进行提交代码,我们执行的命令是:
git checkout newImage ; git commit

git checkout newImage ; git commit命令执行之后

分支与合并

merge
假如我们现在有两个分支,每一个分支上面都有一个独立的提交记录。这就意味着没有一个分支包含我们所有的修改的内容,我们要将这两个分支进行合并,现在我们看一下分支的情况:

分支的合并

现在我们将bugFix合并到master分支上面,使用命令:git merge bugFix

合并之后的样式

但是我们希望将master 分支合并到bugFix上面,我们需要先进行分支的切换,然后在进行合并,具体的命令如:git checkout bugFix; git merge master

git checkout bugFix; git merge master执行之后

上面这样执行的是因为master继承自bugFix,多以Git什么都不需要做,知识简单的把bugFix移动到master指向的那个提交记录就可以了。
rebase
我们要是想将bugFix分支直接移到master分支上面,移动以后会让两个分支的功能看起来像按顺序开发的,但是实际上他们是并行开发的

分支的合并前

我们执行git rebase master,现在bugFix的分支上面的工作在master分支的最顶端,我们看一下C3依然存在,而C3'是我们Rebase到master分支上的C3副本,现在的问题是master还没有更新,我们线面进行master分支的更新。

分支合并后

现在我们先切换到master分支上面,把它rebase到bugFix上面,合并的命令:git rebase bugFix

更新master

在提交树上移动

HEAD
HEAD是一个对当前检出记录的符号引用-- 也就是指向我们正在这个基础上进行工作的提交记录。
HEAD总是指向当前分支最近一次的提交情况。HEAD通常情况下指向分支名,在提交的时候,改变了分支的状态,这一改变导致HEAD是可见的。

提交前

执行命令:git checkout C1; git checkout master ;git commit; git checkout c2

执行命令后

分离的HEAD
分离的HEAD就是让其指向了某一个具体的提交记录,而不再是分支名
我们看一下现在的情况是:HEAD指向master,master指向c1

HEAD的指向

如果我们使用指令git checkout C1

HEAD的指向发生了改变

现在的执行变成了:HEAD指向C1
相对引用

  • 我们可以使用^向上移动一个提交记录
  • 使用^<num>向移动多个提交记录
相对引用的具体应用

我们可以看一下,根据上面的意思也就是master^ 就是master的父节点。
所以我们执行命令git checkout master ^

HEAD的位置发生了变化

我们也可以将HEAD作为相对引用的参照,我们现在就举个栗子:
执行命令:git checkout C3; git checkout HEAD ^; git checkout HEAD ^; git checkout HEAD ^
执行命令前:

before

执行命令后:

after1

依次上移,直到:

finally

~操作符

如果在提交树上向上移动很多步骤的话,要敲很多的^,这样的就很麻烦,Git也考虑到了这一点,于是又引入先操作符~。
这个操作符后面可以和一个数字(可选,不跟数字时与^相同,向上移动一次),指定向上移动多少次。
后退之前:

一次性后退四次

执行:git checkout HEAD~4

后退四次之后

我使用相对引用最多的就是移动分支,可以直接使用-f选项让分支指向另一个提交。

git branch -f master HEAD^3:会将master分支强制指向HEAD的第3级父提交。

执行前:

执行命令之前

执行后:

执行命令之后

相关文章

  • Git常规使用

    Git怎么使用?使用 git commit 进行提交操作时,Git都做了什么? Git怎么使用? 下载、安装Git...

  • GIT和Github

    #Git的初识 ##Git 的使用 Git 使用初尝试 新建项目来操作 克隆已有项目来操作 Git 的使用 by ...

  • AD 使用 Git 的注意事项

    使用 Git 管理项目 Altium Designer 支持使用 Git/SVN 用以版本控制。如果使用 Git,...

  • git

    使用git add . 代替 git add *使用git add之后,怎样恢复?

  • git代理配置

    git http 使用 http proxy git http 使用 https proxy git http 使...

  • Git命令使用

    Git命令使用 前言在使用Git命令之前都使用可视化工具SourceTree操作git,现在需要Git Andro...

  • vscode操作git总让输入用户名密码

    clone使用git地址,不要使用https地址修改.git/config文件中的url = git@git.pl...

  • Git 的基本使用

    Git相关命令 安装Git 在Windows上安装Git (我是使用的Windows)在Windows上使用Git...

  • 前端学习路线(2)——Git使用、DIV+CSS布局

    Git使用、DIV+CSS布局 1. Git使用 链接:git下载链接:git for windows(下载速度可...

  • Git 18使用别名

    GIt 使用别名 ======== 在Git中可以将经常使用的命令以别名缩写的方式简化使用 命令 git conf...

网友评论

      本文标题:git的使用

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