
敲黑板!你和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、合并请求和代码评审。
在讨论这三条简单规则前,请先完成以下任务:
如果你对 Git 和 Github 还不熟悉,请先从 HubSpot 上完成这个很棒的教程:https://product.hubspot.com/blog/git-github;
如果你还不了解 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 次,你就会对它们得心应手了。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
CDA 数据分析师报考条件详解与准备指南 在数据驱动决策的时代浪潮下,CDA 数据分析师认证愈发受到瞩目,成为众多有志投身数 ...
2025-07-18刚入职场或是在职场正面临岗位替代、技能更新、人机协作等焦虑的打工人,想要找到一条破解职场焦虑和升职瓶颈的系统化学习提升 ...
2025-07-182025被称为“AI元年”,而AI,与数据密不可分。网易公司创始人丁磊在《AI思维:从数据中创造价值的炼金术 ...
2025-07-18CDA 数据分析师:数据时代的价值挖掘者 在大数据席卷全球的今天,数据已成为企业核心竞争力的重要组成部分。从海量数据中提取有 ...
2025-07-18SPSS 赋值后数据不显示?原因排查与解决指南 在 SPSS( Statistical Package for the Social Sciences)数据分析过程中,变量 ...
2025-07-18在 DBeaver 中利用 MySQL 实现表数据同步操作指南 在数据库管理工作中,将一张表的数据同步到另一张表是常见需求,这有助于 ...
2025-07-18数据分析师的技能图谱:从数据到价值的桥梁 在数据驱动决策的时代,数据分析师如同 “数据翻译官”,将冰冷的数字转化为清晰的 ...
2025-07-17Pandas 写入指定行数据:数据精细化管理的核心技能 在数据处理的日常工作中,我们常常需要面对这样的场景:在庞大的数据集里精 ...
2025-07-17解码 CDA:数据时代的通行证 在数字化浪潮席卷全球的今天,当企业决策者盯着屏幕上跳动的数据曲线寻找增长密码,当科研人员在 ...
2025-07-17CDA 精益业务数据分析:数据驱动业务增长的实战方法论 在企业数字化转型的浪潮中,“数据分析” 已从 “加分项” 成为 “必修课 ...
2025-07-16MySQL 中 ADD KEY 与 ADD INDEX 详解:用法、差异与优化实践 在 MySQL 数据库表结构设计中,索引是提升查询性能的核心手段。无论 ...
2025-07-16解析 MySQL Update 语句中 “query end” 状态:含义、成因与优化指南 在 MySQL 数据库的日常运维与开发中,开发者和 DBA 常会 ...
2025-07-16如何考取数据分析师证书:以 CDA 为例 在数字化浪潮席卷各行各业的当下,数据分析师已然成为企业挖掘数据价值、驱动决策的 ...
2025-07-15CDA 精益业务数据分析:驱动企业高效决策的核心引擎 在数字经济时代,企业面临着前所未有的数据洪流,如何从海量数据中提取有 ...
2025-07-15MySQL 无外键关联表的 JOIN 实战:数据整合的灵活之道 在 MySQL 数据库的日常操作中,我们经常会遇到需要整合多张表数据的场景 ...
2025-07-15Python Pandas:数据科学的瑞士军刀 在数据驱动的时代,面对海量、复杂的数据,如何高效地进行处理、分析和挖掘成为关键。 ...
2025-07-15用 SQL 生成逆向回滚 SQL:数据操作的 “后悔药” 指南 在数据库操作中,误删数据、错改字段或误执行批量更新等问题时有发生。 ...
2025-07-14t检验与Wilcoxon检验的选择:何时用t.test,何时用wilcox.test? t 检验与 Wilcoxon 检验的选择:何时用 t.test,何时用 wilcox. ...
2025-07-14AI 浪潮下的生存与进阶: CDA数据分析师—开启新时代职业生涯的钥匙(深度研究报告、发展指导白皮书) 发布机构:CDA数据科 ...
2025-07-13LSTM 模型输入长度选择技巧:提升序列建模效能的关键 在循环神经网络(RNN)家族中,长短期记忆网络(LSTM)凭借其解决长序列 ...
2025-07-11