敲黑板!你和GitHub高手就差这三条规则······

作者:Ariel Camus

机器之心编译 参与:高璇、路

本文转自机器之心,转载需授权

本文作者 Ariel Camus 介绍了每天使用 Git 和 GitHub 的重要性,还分享了三个帮助大家成为 Git 和 GitHub 高手的简单规则。

本文不会介绍如何创建 GitHub 简历或如何使用终端提交 Git。我将解释每天使用 Git 和 GitHub 的重要性,尤其对于正在学习写代码的人。我还将分享并讨论三个简单的规则,你可以通过遵循这些规则,变成一个优秀的 Git 和 GitHub 使用者。

为什么 Git 和 GitHub 如此重要?

如果你正在学习编程,而且你的终极目标是获得一份软件开发的工作。在这种情况下,答案很简单:

学习 Git 和 GitHub 非常重要,因为 99% 的公司都会使用 Git 和 GiHub。所以,学习使用 Git 和 GitHub 可以让你更容易被雇佣,并且能将你和初级开发者区别开来。

高级开发者之所以成为高级开发者,并不是因为他们更了解特定语言的语法,而是他们有和真实用户一起处理大型复杂项目和完成业务目标的经验。

当你仍在学习写代码阶段时,你很难获得这种经验。然而,获得现实世界经验的一个简单方法就是利用现实世界项目使用的工具和方法。Git 和 GitHub 就是一个例子。

你还可以做的事情:远程结对编程、为开源做贡献、为你的简历构建专业设计网站。

即使你同意「掌握 Git 和 GitHub 有助于找工作」,你可能仍然会想:

「为什么 Git 和 Github 对公司如此重要?」

简而言之,Git 允许团队以异步方式高效地为同一个项目贡献代码。这使得团队能够更好地协作,从而解决更大更复杂的问题。

Git 是一个分布式版本控制系统,它还提供取消更改、创建代码分支、解决合并冲突等机制。这些都是非常有用的特性,可以解决每个软件团队每天都面临的特定问题和常见问题。Git 是当今的主流解决方案。

另一方面,GitHub 是 Git 之上的附加层,它为其他特定和常见问题提供解决方案,比如代码审查、pull request、问题管理/bug 跟踪等等。

注:尽管 Git 是大多数公司的首选版本控制解决方案,但 GitHub 仍然有一些强大的竞争对手,比如 GitLab 和 Bitbucket。但是,如果你知道如何使用 GitHub,那么你就能驾轻就熟地使用 GitLab 或 Bitbucket。

现在你已经了解了掌握 Git 和 Github 的重要性,接下来我们来看三个简单规则,它们可以让你在学习编写代码阶段,就轻松成为专业的 Git 和 Github 用户。

如何利用 3 条简单规则掌握 Git 和 Github?

我是 Microverse 的创始人,Microverse 是一所面向远程软件开发人员的学校,在你找到工作前完全免费使用。我们在 22 周计划中,不仅教学生如何编程,同时也会给他们大量的指导和构思,让他们在计划中获得实际经验。

为了成为专业的 Git 和 Github 用户,我们要求学生遵循以下三个规则。培训结束后,我们的学生应该能自然而然运用 Git、GitHub、branch、合并请求和代码评审。

在讨论这三条简单规则前,请先完成以下任务:

  1. 如果你对 Git 和 Github 还不熟悉,请先从 HubSpot 上完成这个很棒的教程:https://product.hubspot.com/blog/git-github;
  2. 如果你还不了解 GitHub 流,你应该先学习它,因为我们后边会用到:https://guides.github.com/tion/flow/。

无需多言,三条能令你在学习编程阶段就能熟练掌握 Git 和 Github 的简单规则如下:

  • 规则 #1:为每个新项目创建一个 Git 仓库
  • 规则 #2:为每个新特性创建一个新分支
  • 规则 #3:使用 Pull Request 将代码合并到 Master 分支

即使你的项目非常简单或者你只是单独工作,但只要在每次编程时遵循这三条规则,你很快就可以成为 Git 和 GitHub 的使用高手。

我们会简单分析每条规则,以便你理解该如何做以及为什么这些规则很重要。

规则 #1:为每个新项目创建一个 Git 仓库

第一条规则很简单,但是养成习惯非常重要。每当你开始一个新项目时,如你的简历、学习项目、编程挑战的解决方案等等,你都应该创建一个新的 Git 仓库,并将其推送到 GitHub 上。

拥有专用的 repo 是为你编写的每一行代码使用版本控制的第一步。使用版本控制是你加入公司、开始从事实际项目后的工作方式。及早学习并养成习惯。

注:如果使用终端比较麻烦,你无法在所有项目中使用 Git,可以考虑使用 Github 桌面应用程序(https://desktop.github.com/)。

规则 #2:为每个新特性创建一个新分支。

假设你希望在简历里构建一个新的「Contact me」部分/组件。那么为这个新特性创建一个专用的分支,给它一个有意义的名称(例如 contact-me-section),并将所有代码提交给这个特定的分支。

如果你不知道何为分支,请返回到 Github 流(https://guides.github.com/guidetion/flow/),阅读我之前推荐的内容。

使用分支可以让你和团队成员以并行的方式处理不同的特性,同时将每个特性的代码与其他代码区分开来。这使得不稳定的代码不会轻易并到主代码库中。

即使你是团队中唯一的成员,一旦你真正开始工作,熟练使用特性分支会使 GitHub 流的过程变得轻而易举。

规则 #3:使用 Pull Request 将代码合并到 Master 分支

默认情况下,每个仓库都从一个主分支开始。永远不要直接在主分支上进行改动。相反,你应该使用特性分支,并打开一个新的 PR,将特性分支代码与主分支代码合并。

在现实工作中,会有人查看你的 Pull Request,并在批准前进行代码审查。GitHub 甚至会对你的代码进行自动测试,让你知道它是否有问题。如果你的代码与主分支代码之间存在合并冲突,你也会收到通知。例如,如果另一个开发人员推送到主分支的更改影响了你修改过的文件时,就会发生这种情况。

在代码经过审查、测试和批准之后,reviewer 会允许你合并 Pull Request,或者他们直接合并你的 Pull Request。

即使你单独工作,也要习惯于创建 Pull request,以便将更改合并到主分支。这是几乎所有开源项目使用的基本工作流程。如果你曾经贡献过某个项目,理解这三个规则将让你的贡献很容易被接受。

结语

如果你仍然感到困惑,那就慢慢来,记住这三条规则。不要试图去想「如何做」,而要专注于「做什么」和「为什么」。

一旦「做什么」和「为什么」清楚了,在时机成熟时你就能知道「如何做」了。重复这个过程 2-3 次,你就会对它们得心应手了。

原文链接:

https://medium.freecodecamp.org/follow-these-simple-rules-and-youll-become-a-git-and-github-master-e1045057468f

原文发布于微信公众号 - CDA数据分析师(cdacdacda)

原文发表时间:2018-08-17

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏CSDN技术头条

工业物联网通讯框架 ServerSuperIO 的实践应用

概述 不知从何时起,物联网、大数据、云计算……等一大批概念词汇流行起来,占领着各大 IT 网站。不能把这三个语汇独立来看,而是现实系统体系化建设的三个方面。物联...

31890
来自专栏Java架构师历程

微服务架构是什么

架构师在软件行业一直有很高的位置,并且在开会中的架构师都带有主角光环。 架构师是可以说是软件的设计者,运用我们学会就会忘记的23种设计模式、企业架构模式、面向对...

67120
来自专栏互扯程序

到底什么是分布式系统,该如何学习

现在是资源共享的时代,同样也是知识分享的时代,如果你觉得本文能学到知识,请把知识与别人分享。

17850
来自专栏用户3254834的专栏

干货丨小程序功能解读白皮书(一)

在微信公众平台里,关于小程序的消息目前停留在8月10号,这次公布了支持查看”我的小程序”添加数据、插件支持快速更新、小程序流量主广告收入分成比例上调等能力开放,...

14220
来自专栏架构之美

五分钟学会智能多通道推送(PUSH)技术

38020
来自专栏IT技术精选文摘

京东网络接入体系解密之高性能四层网关DLVS

DLVS诞生之初 在SLB这块,京东用户接入系统提供四层负载均衡服务和应用层负载均衡服务,对于公网流量接入部分,和很多公司一样采用的是四层和应用层负载相结合的架...

54190
来自专栏织云平台团队的专栏

腾讯SNG全链路日志监控平台之构建挑战

全链路日志监控在现在盛行的微服务和分布式环境下,能有效地提高问题定位分析效率,成为开发和运维利器。当前已有开源解决方案和成熟的厂商提供。

1.3K00
来自专栏大数据杂谈

被称为“开发者神器”的GitHub,到底该怎么用?

导读:GitHub是一个拥有数十亿行代码的网站,每天有数百万开发者聚集在一起,研究开源软件中存在的问题。开发人员每天都要在工作中使用GitHub或其他基于Git...

10930
来自专栏魏艾斯博客www.vpsss.net

wodpress 博客禁止对某篇文章发表评论的方法

20530
来自专栏数据和云

【从根源出发,化风险为可控】应用到数据库的连接数管控

作者介绍 ? 巩飞(Morinson) 云和恩墨技术专家 网名Morinson,现服务于云和恩墨西北区,有14年在IT公司的技术类工作经验,特别是在 Ora...

32450

扫码关注云+社区

领取腾讯云代金券