一文看懂 Github

GitHub 介绍

GitHub 是为开发者构建的一个开发平台。GitHub 是一个受开发者工作方式启发的开发平台,从开源到商业,能够在上面进行托管和查看代码、管理项目和数百万其他开发人员一起开发软件。GitHub 提供免费账户和付费账户,免费账户只能创建开源的项目,付费账户可以创建私有项目。对学生有一定的福利,如果你是学生的话,可以用学校分配的邮箱在官网进行申请,申请通过之后,也能够创建私有项目。

要完成本教程,你需要一个 GitHub 帐户,可以在官网进行注册。

下面将分别介绍 GitHub 的基本内容,如仓库分支提交请求合并。在这里以创建 HelloWorld 仓库为例,并学习 GitHub 的其它内容。

1、创建仓库

仓库通常用于组织单个项目。仓库可以包含文件夹和文件、图片、视频呢、电子表格和数据集以及项目需要的任何东西。每个仓库下面都推荐有一个 README 文件,或者是一个包含项目信息的文件。可以在仓库中存储想法、资源,甚至可以与其他人共享和讨论问题。

创建一个新的仓库

1、在左边的栏目中或者头像旁边点击 +,然后点击新建仓库。

2、仓库的名称,我们设置为 HelloWorld。

3、给仓库写一个简单的描述,几句话介绍下该项目。

4、选择初始化仓库的时候,创建 README 文件。

5、点击创建仓库,完成仓库的创建。

 2、创建分支

分支是一次处理不同版本仓库的一种方式。默认情况下,仓库下面有一个名为 master 的分支,这是我们的主分支,也是最终的版本。我们使用其它分支来进行实验,在提交到主分支的之前,我们可以对分支进行编辑等操作。当我们在主分支上创建一个分支时,相当于我们从主分支上的复制或者是快照,这样当我们在自己的分支上工作时,如果其他人对主分支进行了更改,我们可以通过 Pull 操作来更新代码。每个分支都是独立的,一个项目可以有多个分支,每个人开发属于自己的一个模块,最后统一合并到主分支。

下面的图展示了

1、主分支(master)。

2、新的分支,名字叫 feature,每个分支都是对功能的扩展。

3、feature 分支被 master 合并的整个过程。

当你在主分支上创建一个分支时,相当于复制,或者快照。如果你在分支上工作时,其他人对主分支进行了更改,你可以通过 pull,进行更新到最新的代码。

你是否保存过不同版本的文件,如:

store.txt

store-zhw-edit.text

store-zhw-edit-reviewed.txt

分支就是用来解决这样的事情,在 GitHub 上,开发人员、作者和设计人员使用分支将 bug 修复和开发功能与我们的主分支分开,当一个变更准备好了,我们就将对应的分支合并到主分支。

创建一个新的分支

1、进到我们刚才创建的 HelloWorld 仓库。

2、点击上方文件列表中的分支 master。

3、在新的分支文本框中输入一个分支名称,readme-edits。

4、选择蓝色的创建分支框或点击回车键。

现在有两个分支,master 和 readme-edits。它们看起来完全一样,但不会太久! 接下来,我们将添加对新分支的更改。

3、修改和提交修改

我们现在所在的 readme-edits 分支,这是一个 master 的副本,接下来让我们做一些编辑。在 GitHub 上,保存的更改称为提交,每个提交都有一个关联的提交消息,这是对你做的修改进行描述,当你提交了更改,其他的贡献者通过描述可以知道你做了什么。

修改和提交修改

1、点击 README.md 文件。

2、点击右边的第二个铅笔图标进行修改。

3、在编辑区,写下关于自己的介绍。

4、填写提交信息,描述本次的更新。

5、点击提交变化按钮。

这些更改这是针对当前的 readme-edits 分支中的 README 文件,现在这个分支包含的内容与 master 上的内容是不同的。

4、请求合并分支(PR)

现在我们已经更改了分支,可以对主分支进行 Pull Request。Pull Request 是 GitHub 上合作的核心,当你发出一个 Pull Request 时,你是在提出你的变更,请求别人审查并将你做出的改变(贡献)合并到他们的分支中。Pull Request 显示来自两个分支内容的差异,这些变化,增加的内容以绿色来表示,减少的内容以红色来表示。

当你完成工作时,你可以进行提交,通过提出 Pull Request 并开始讨论,你可以在 Pull Request 时,使用 @,请求特定的人员或团队来审核。

为改变过的 README 文件,打开 Pull Request

1、点击 Pull Request  选项,然后在 Pull Request 页面,点击绿色的 New Pull Request 按钮。

选择我们创建的分支,readme-edits,以便与 master 进行比较。

查看文件的变化,确保这些都是你要提交的。

当检查好了之后,并没有任何错误,可以点击这个绿色的按钮,创建一个 Pull Request。

点击之后,给出本次 Pull Request 的 title 和描述。

以上都完成之后,点击绿色按钮创建。

5、合并 Pull Request

在这最后一步,是将之前的变更合并到主分支上,也就是将 readme-edits 分支合并到 master 分支上。

1、点击绿色按钮,合并变更到 master。

2、点击确认合并。

到这里你已经学会了在 GitHub 上创建仓库和怎么在别人的项目中贡献自己的一份力量。

你在本次学习中完成了下面的作业。

1、创建一个开源项目。

2、创建和合并分支。

3、改变文件内容,并将变更提交到 GitHub 上。

4、提出 Pull Requet 和合并一个 Pull Request。

PS:如果觉得文章不错的话,还请大家点赞分享下,算是对我的最大支持。

推荐阅读:

Java  学习经验总结

SSH配置—Linux下实现免密码登录

Java 学习资料

原文地址:https://www.cnblogs.com/hanwen1014/p/9064400.html

时间: 2024-08-27 20:21:43

一文看懂 Github的相关文章

一文看懂命令行参数的用法——Python中的getopt神器

一文看懂命令行参数的用法--Python中的getopt神器 参考原文:Python模块之命令行参数解析 - 每天进步一点点!!! - 博客园 https://www.cnblogs.com/madsnotes/articles/5687079.htmlpython getopt使用 - tianzhu123的专栏 - CSDN博客 https://blog.csdn.net/tianzhu123/article/details/7655499在运行程序时,可能需要根据不同的条件,输入不同的命令

[转帖]一文看懂mysql数据库本质及存储引擎innodb+myisam

一文看懂mysql数据库本质及存储引擎innodb+myisam https://www.toutiao.com/i6740201316745740807/ 原创 波波说运维 2019-09-29 00:01:00 概述 今天主要讲下mysql数据库引擎的一些概念和mysql数据库本质,一句话总结: 文件夹-文件:一个数据库其实就是一个的文件夹,数据库里面的表就是文件夹里的一个或者多个文件(根据数据库引擎不同而不同,MyISAM是3个,InnoDB是2.5个) mysql的数据库其实就是存放在M

一文看懂java io系统 (转)

出处:  一文看懂java io系统 学习java IO系统,重点是学会IO模型,了解了各种IO模型之后就可以更好的理解java IO Java IO 是一套Java用来读写数据(输入和输出)的API.大部分程序都要处理一些输入,并由输入产生一些输出.Java为此提供了java.io包 java中io系统可以分为Bio,Nio,Aio三种io模型 关于Bio,我们需要知道什么是同步阻塞IO模型,Bio操作的对象:流,以及如何使用Bio进行网络编程,使用Bio进行网络编程的问题 关于Nio,我们需

一文看懂HashMap

一文看懂HashMap 总所周知HashMap是面试中经常问到的一个知识点,也是判断一个候选人基础是否扎实的标准之一,因为通过HashMap可以引出很多知识点,比如数据结构(数组.链表.红黑树).equals和hashcode方法,除此之外还可以引出线程安全的问题,HashMap是我在初学阶段学到的设计的最为巧妙的集合,里面有很多细节以及优化技巧都值得我们深入学习,话不多说先看看相关的面试题: 默认大小.负载因子以及扩容倍数是多少 底层数据结构 如何处理hash冲突的 如何计算一个key的has

从概念到底层技术,一文看懂区块链架构设计

转自:http://www.8btc.com/ebook-blockchain https://blog.csdn.net/lucky_greenegg/article/details/52821924 前言 区块链作为一种架构设计的实现,与基础语言或平台等差别较大.区块链是加密货币背后的技术,是当下与VR虚拟现实等比肩的热门技术之一,本身不是新技术,类似Ajax,可以说它是一种技术架构,所以我们从架构设计的角度谈谈区块链的技术实现. 无论你擅长什么编程语言,都能够参考这种设计去实现一款区块链产

一文看懂大数据的技术生态圈

大数据本身是个很宽泛的概念,Hadoop生态圈(或者泛生态圈)基本上都是为了处理超过单机尺度的数据处理而诞生的.你可以把它比作一个厨房所以需要的各种工具.锅碗瓢盆,各有各的用处,互相之间又有重合.你可以用汤锅直接当碗吃饭喝汤,你可以用小刀或者刨子去皮.但是每个工具有自己的特性,虽然奇怪的组合也能工作,但是未必是最佳选择. 大数据,首先你要能存的下大数据. 传统的文件系统是单机的,不能横跨不同的机器.HDFS(Hadoop Distributed FileSystem)的设计本质上是为了大量的数据

一文看懂 K8s 日志系统设计和实践

上一篇中我们介绍了为什么需要一个日志系统.为什么云原生下的日志系统如此重要以及云原生下日志系统的建设难点,相信DevOps.SRE.运维等同学看了是深有体会的.本篇文章单刀直入,会直接跟大家分享一下如何在云原生的场景下搭建一个灵活.功能强大.可靠.可扩容的日志系统. 需求驱动架构设计 技术架构,是将产品需求转变为技术实现的过程.对于所有的架构师而言,能够将产品需求分析透彻是非常基本也是非常重要的一点.很多系统刚建成没多久就要被推翻,最根本的原因还是没有解决好产品真正的需求. 我所在的日志服务团队

一文看懂Kafka消息格式的演变

摘要 对于一个成熟的消息中间件而言,消息格式不仅关系到功能维度的扩展,还牵涉到性能维度的优化.随着Kafka的迅猛发展,其消息格式也在不断的升级改进,从0.8.x版本开始到现在的1.1.x版本,Kafka的消息格式也经历了3个版本.本文这里主要来讲述Kafka的三个版本的消息格式的演变,文章偏长,建议先关注后鉴定. Kafka根据topic(主题)对消息进行分类,发布到Kafka集群的每条消息都需要指定一个topic,每个topic将被分为多个partition(分区).每个partition在

【转发】一文看懂python主要应用领域或应用场景

转发来源: http://www.elecfans.com/d/644370.html Python简介 Python(英国发音:/?pa?θ?n/美国发音:/?pa?θɑ?n/),是一种面向对象的解释型计算机程序设计语言,由荷兰人GuidovanRossum于1989年发明,第一个公开发行版发行于1991年. Python是纯粹的自由软件,源代码和解释器CPython遵循GPL(GNUGeneralPublicLicense)协议.Python语法简洁清晰,特色之一是强制用空白符(whites