我一直听到有人说他们在Git中分叉代码。Git“fork”听起来很可疑,就像Git“clone”加上放弃未来合并的心理意愿(毫无意义)。Git中没有fork命令,对吧?
GitHub通过将通信钉在分叉上,让分叉变得更加真实。也就是说,你按下分叉按钮,然后,当你按下拉请求按钮时,系统足够智能,可以给所有者发送电子邮件。因此,这有点像是围绕存储库所有权和权限跳舞。
是/否?对GitHub向这个方向扩展Git有什么担忧吗?或者有传言说Git吸收了这个功能?
我一直听到有人说他们在Git中分叉代码。Git“fork”听起来很可疑,就像Git“clone”加上放弃未来合并的心理意愿(毫无意义)。Git中没有fork命令,对吧?
GitHub通过将通信钉在分叉上,让分叉变得更加真实。也就是说,你按下分叉按钮,然后,当你按下拉请求按钮时,系统足够智能,可以给所有者发送电子邮件。因此,这有点像是围绕存储库所有权和权限跳舞。
是/否?对GitHub向这个方向扩展Git有什么担忧吗?或者有传言说Git吸收了这个功能?
当前回答
当你决定为某个项目做出贡献时,就完成了分叉。您将制作整个项目及其历史日志的副本。此副本完全在您的存储库中创建,一旦您进行了这些更改,就会发出拉取请求。现在,由源代码所有者来接受拉取请求,并将更改合并到原始代码中。
Gitclone是一个实际的命令,允许用户获取源代码的副本。git克隆这将在您自己的本地存储库中创建[URL]的副本。
其他回答
在GitHub上下文中,Fork没有扩展Git。它只允许在服务器端进行克隆。
当您在本地工作站上克隆GitHub存储库时,除非您被明确声明为“贡献者”,否则无法向上游存储库进行贡献。这是因为您的克隆是该项目的单独实例。如果您想为项目做出贡献,可以使用forking,方法如下:
在您的GitHub帐户上克隆GitHub存储库(即“fork”部分,服务器端的克隆)提交到GitHub存储库(它在您自己的GitHub帐户中,因此您完全有权推送它)向原始GitHub存储库发送任何有趣的贡献(即通过对自己的GitHub库所做的更改发出的“拉取请求”部分)
另请查看“协作GitHub工作流”。
如果要保持与原始存储库的链接(也称为上游),则需要添加一个远程引用该原始存储库。请参阅“GitHub上的源代码和上游代码之间的区别是什么?”
随着Git 2.20(2018年第四季度)及更高版本的发布,使用三角洲岛,从fork获取数据的效率更高。
克隆涉及将git存储库复制到本地计算机,而分叉则是将存储库克隆到另一个存储库。克隆仅供个人使用(尽管将来可能会发生合并),但通过分叉,您可以复制并打开一个新的可能的项目路径
简单地说,
当你说你正在分叉一个存储库时,你基本上是在GitHub帐户中的GitHub ID下创建一个原始存储库的副本。
and
当你说要克隆一个存储库时,你是在你的系统(PC/笔记本电脑)中直接创建原始存储库的本地副本,而GitHub帐户中没有副本。
我认为fork是其他存储库的副本,但有您的帐户修改。例如,如果您直接在本地克隆其他存储库,则远程对象源仍然使用您克隆的帐户。你不能提交和贡献你的代码。它只是代码的纯拷贝。否则,如果您分叉了一个存储库,它将通过更新github帐户中的帐户设置来克隆回购。然后在您的帐户上下文中克隆回购,您可以提交代码。
我一直听到有人说他们在用git分叉代码。Git“fork”听起来像Git“clone”,加上放弃未来合并的心理意愿(毫无意义)。git中没有fork命令,对吗?
“分叉”是一个概念,不是任何版本控制系统都特别支持的命令。
最简单的分叉与分支同义。每次创建分支时,无论VCS如何,都会“分叉”。这些分叉通常很容易合并在一起。
你所说的那种分叉,即一个单独的一方获取代码的完整副本并走开,必然发生在VCS之外的Subversion这样的集中式系统中。像Git这样的分布式VCS对分叉整个代码库和有效启动新项目有更好的支持。
Git(而不是GitHub)本机支持以两种方式“分叉”整个repo(即克隆它):
克隆时,将为您创建一个名为origin的远程默认情况下,克隆中的所有分支都将跟踪其原始分支从您派生的原始项目中获取和合并更改非常简单
Git使得将更改返回到fork的源代码变得简单,就像请求原始项目中的某个人从您那里提取,或者请求写访问权限将更改推回到您自己。这是GitHub使之更容易和标准化的部分。
Github向这个方向扩展git有什么焦虑吗?或者有传言说git吸收了这个功能?
没有焦虑,因为你的假设是错误的。GitHub通过一个漂亮的GUI和一种标准化的拉请求发出方式“扩展”了Git的分叉功能,但它并没有将该功能添加到Git中。完全回购分叉的概念在基本层面上直接融入到分布式版本控制中。你可以随时放弃GitHub,继续推/拉你“分叉”的项目。