在学习git的过程中,我不断遇到HEAD、master、origin这些术语,我不确定它们之间有什么区别。如果我理解正确的话,HEAD总是等于最新的版本?如果是的话,这是整个存储库的最新版本,还是特定分支或标记的最新版本?这太让人困惑了。我已经阅读了许多关于这方面的教程以及分支/合并等内容,但仍然无法理解它。
当前回答
虽然这并不能直接回答问题,但有一本很棒的免费书籍可以帮助你学习基础知识 ProGit。如果你更喜欢死木版本,而不是比特集合,你可以从亚马逊购买。
其他回答
我强烈推荐Scott Chacon的《Pro Git》这本书。花点时间认真阅读它,同时探索实际的git回购。
当前的提交你的回购是在。大多数情况下,HEAD指向当前分支中的最新提交,但情况不一定如此。HEAD实际上只是表示“我的回购当前指向的是什么”。
如果提交HEAD指向的不是任何分支的顶端,这被称为“分离头”。
Master: git在第一次创建repo时为你创建的默认分支的名称。在大多数情况下,“master”指的是“主要分支”。大多数商店都让每个人都向主人推销,主人被认为是回购的最终观点。但是对于发布分支来说,脱离master来发布也是很常见的。本地回购有自己的主分支,它几乎总是跟随远程回购的主分支。
Origin: git给你的主远程repo的默认名称。你的盒子有自己的回购,你很可能会推出一些远程回购,你和你所有的同事都推到那里。这个远程回购几乎总是被称为原点,但它并不一定要这样。
HEAD是git中的官方概念。HEAD总是有一个明确定义的含义。Master和origin是git中常用的名称,但它们不一定是。
虽然这并不能直接回答问题,但有一本很棒的免费书籍可以帮助你学习基础知识 ProGit。如果你更喜欢死木版本,而不是比特集合,你可以从亚马逊购买。
HEAD不是最新的版本,而是当前的版本。通常,它是当前分支的最新版本,但也不一定非得如此。
Master是通常用于主分支的名称,但也可以称为其他任何名称(也可以没有主分支)。
原点通常是主遥控器的名称。Remote是另一个可以从中提取和推送的存储库。通常是在某个服务器上,比如github。
推荐文章
- 当git说它正在“解析delta”时,它实际上在做什么?
- Git命令将一个文件夹移动到另一个文件夹
- 在单个文件中重新启动/撤消冲突解决方案
- Visual Studio代码如何解决合并冲突与git?
- 无法推送到远程分支,无法解析到分支
- Git:如何将数据库重置为特定的提交?
- 如何在合并期间使用Git和命令行保存本地文件或远程文件?
- 能够用一个命令推到所有git遥控器?
- 重新基于Git合并提交
- 忽略已经签入目录的内容?
- 如何从windows cmd保存git提交消息?
- (Mac) -bash: __git_ps1:命令未找到
- 如何删除多个已删除的文件在Git仓库
- 使用vimdiff查看所有' git diff '
- 如何拉特定的目录与git