Git所有命令图解

2023年 10月 6日 20.7k 0

根据Git学习免费网站整理,真的非常适合学习Git的一个网站。

说在前面:

  • 带*号的就是当前所指分支(也就是HEAD指针所指)
  • C1、C2这些是每次commit的hash值
  • git commit

    最朴素的就是git commit,一次提交对应一次版本

    image.png

    git branch 和 git checkout

    注意此时*并不在bugFix分支上

    image.png

    需要使用checkout指令切换分支

    image.png

    当然这两个命令可以一起合并!

    git checkout -b bugFix(这个-b就是branch的意思)

    git merge

    image.png
    如果此时再git checkout然后git merge main效果是一样的,因为C5是继承的C4

    (当然git merge的过程中可能会出现冲突,一般是多个分支一起修改了一个文件导致的,需要手动解决)

    git rebase

    Rebase 实际上就是取出一系列的提交记录,“复制”它们,然后在另外一个地方逐个的放下去。

    Rebase 的优势就是可以创造更线性的提交历史,这听上去有些难以理解。如果只允许使用 Rebase 的话,代码库的提交历史将会变得异常清晰。

    image.png

    HEAD指针

    在我们每次提交的时候,HEAD指针都是跟随main移动的状态

    image.png

    可以在有.git目录下输入cat .git/HEAD命令查看

    image.png

    上面说的HEAD一般都指向分支名,但是我们可以用checkout命令将HEAD指向具体的提交记录,而不是具体的分支名,比如 git checkout C1

    相对引用

    简而言之,上面我们用到的C1、C2(实际是每次commit对应的hash,用git log查看),这就是直接指定checkout到哪儿,与此相对的就是相对引用。
    ^就是往上一个,~num,num是几就向上几个

    image.png

    git reset和git revert

    比如git reset HEAD~1就是退回HEAD上一个

    image.png

    git revert有点不同,这也跟他和reset的区别有关。reset是本地的回退,revert是远程的回退

    所以git revert HEAD

    此时C2‘和C1的内容完全一样
    image.png

    git chery-pick

    就像名字一样,摘樱桃🍒,把另一个分支里需要的提交拿过来,注意顺序

    image.png

    git pull和git fetch

    git fetch是将远程主机的最新内容拉到本地,用户在检查了以后决定是否合并到工作本机分支中。而git pull 则是将远程主机的最新内容拉下来后直接合并

    网上流传的git pull = git fetch + git merge很好理解

    相关文章

    JavaScript2024新功能:Object.groupBy、正则表达式v标志
    PHP trim 函数对多字节字符的使用和限制
    新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
    使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
    为React 19做准备:WordPress 6.6用户指南
    如何删除WordPress中的所有评论

    发布评论