Git与GitHub:解锁版本控制的魔法盒子

简介: Git与GitHub:解锁版本控制的魔法盒子



git与GitHub

Git

Git是一种分布式版本控制系统,由Linus Torvalds创造,主要用于帮助多人协作进行软件开发。它用于管理项目的历史记录,包括文件的更改历史和各种版本。

使用Git,开发者可以轻松地克隆现有的项目仓库,进行更改,并提交这些更改,从而与其他开发者共享。此外,Git还能有效地处理大型项目,并支持分支管理,这使得开发者可以并行开发多个功能或修复问题。 Git的主要特点包括:

  1. 分布式版本控制:每个Git仓库都有完整的代码历史记录,因此不需要连接到远程服务器就可以进行许多操作。
  2. 分支管理:可以轻松创建、合并和删除分支,这使得多人在同一个项目中协作变得简单。
  3. 暂存区(Staging Area):允许开发者选择性地暂存文件更改,然后再提交。
  4. 非线性历史:Git允许创建非线性历史记录,这为一些特定的开发场景提供了便利。
  5. 多种协议支持:可以通过HTTP、SSH、Git等多种协议进行网络传输。 Git已成为许多开源项目和许多企业中软件开发的重要组成部分。

简单来说就是:

git是一个版本控制工具. 主要解决三个问题

  1. 代码被喵星人吃掉了.
  2. 产品经理反复修改需求, 需要同时维护多个版本代码.
  3. 多人协同开发

博主的博文有相关林纳斯托瓦兹的介绍,Linux 系统的诞生开始于芬兰赫尔辛基大学的一位计算机系的学生,名字为 Linus Torvalds

Git的由来

Git的由来与Linux内核开发的历史紧密相关。

在Linux内核开发早期,开发者们使用的是一个名为BitKeeper的版本控制系统来管理代码。BitKeeper是由BitMover公司提供的商业软件,它允许开发者克隆整个代码库到本地,并在本地进行更改,然后将更改同步回中央服务器。

然而,2005年,BitMover公司改变了其许可政策,不再允许免费使用BitKeeper,这使得Linux内核开发者们面临一个选择:要么支付高昂的许可费用,要么寻找替代的版本控制系统。

为了继续免费地管理Linux内核的代码,Linux内核创始人Linus Torvalds于2005年7月发布了Git。

Git的设计受到了BitKeeper的影响,但它是一个开源的分布式版本控制系统,这意味着每个开发者都可以拥有完整的代码历史和版本控制功能,而不需要中央服务器。

Git的发布迅速得到了开源社区的广泛支持,并迅速成为最流行的版本控制系统之一,不仅用于Linux内核开发,还用于无数的其他项目和大型软件开发工作。Git的流行也促进了GitHub(一个基于Git的开源代码托管平台)的创建,进一步推动了开源社区的协作和代码共享。

小故事~

以下是来自ubergizmo发布的八卦:

       linus fucked nvidia是在2012年。当时linus在某大学开讲座,问答环节中,有人吐槽自在笔记本电脑上跑个带图形界面的linux好麻烦。linus表现出了极大的同情,他说nvidia想给安卓市场卖大量的芯片,但又不乐意给linux提供支持,非常难缠。原话“the single worst company”。最后linus在激动之下对着摄影机伸出中指fuck了nvidia。

简单来说,意思就是nvidia这么个毫无技术秘密可言的内核驱动,nvidia也不愿意开放编程接口,所以linus很不满。

这个事情今天已经不可能再发生了。

       第一,linus老了之后开始反思自己的过往,觉得自己当年口无遮拦怼天怼地,缺乏同理心,是不对的,也对社区无益。他甚至接受了相关的therapy,人变得比较温和。曾今的嘴臭之王再也干不出对着镜头fuck别人的事情了。

       第二,2012年Alex和Ilya他们还在手搓AlexNet,靠GPU搞AI还在爆发的前夜。nvidia自己可能都还没想到这里有这么大一块业务,自然也懒得给linux投入精力。而nvidia后来这些年靠AI赚飞了,nvidia对linux的支持也就越来越多。虽然大部分核心竞争力,诸如驱动,cuda之类的都还是闭源,但是整体来说还是乐意和开源社区合作。这一点上,linus本人也表示过赞同。

相关链接如下:

GitHub

GitHub是一个基于web的服务平台,用于托管和开发Git仓库。

它提供了Git的分布式版本控制和源代码管理(SCM)功能,同时增加了一些自己的特性,如任务管理、订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等。 GitHub的特点包括:

  1. 社交编码:GitHub允许用户对项目进行关注、点赞、评论和发起议题,这使得软件开发变得更加社交化。
  2. 代码托管:用户可以在GitHub上创建public或private的代码仓库,用于存储和管理项目代码。
  3. 分支管理:用户可以创建和管理仓库的分支,方便多人协作和功能开发。
  4. Pull Requests:用户可以通过Pull Requests(PR)来贡献代码到其他项目,也可以在自己的项目中接受他人的代码贡献。
  5. 代码审查:GitHub的Pull Requests功能内置了代码审查功能,允许项目维护者或其他贡献者审查更改。
  6. 集成:GitHub与其他工具和服务集成,如Continuous Integration(CI)/Continuous Deployment(CD)服务、Issue跟踪工具、代码分析工具等。
  7. GitHub Actions:提供了一个持续集成和持续部署的平台,允许用户自动化构建、测试和部署他们的项目。
  8. Markdown渲染:GitHub支持Markdown语法,使得文档和注释的编写更加简洁和美观。 GitHub成立于2008年,迅速成为最流行的代码托管平台之一,特别是对于开源项目。用户可以通过GitHub进行代码分享、协作和项目管理,它的社交特性也使得软件开发过程中的交流和协作变得更加方便。

简单来说就是:

Github 是 "全球最大的同性社交网站". 通过 git 可以把代码上传到 Github 上给全球的用户分享

下载安装

安装 git for windows

这个是一个git的windows系统的命令行版本

Git - Downloads

安装 tortoise git

这个是git的图形界面.

Download – TortoiseGit – Windows Shell Interface to Git

注意:

  1. 先安装 git for windows, 再安装 tortoise git
  2. 安装 git for windows 一路 next 即可.
  3. 安装 tortoise git 中需要配置 git.exe, 这个是 git for windows 包含的部分. 如果 git for windows 安装成功, 这 一步使用默认结果即可.
  4. 安装 tortoise git 还需要配置姓名和邮箱, 这个尽量和 Github 的邮箱填成一致.
  5. 两个工具安装完毕后, 需要重启电脑才能正确使用.

使用 Github 创建项目

GitHub打不开~

博主发了解决办法,链接如下:

注册账号

这个比较简单, 参考着官网提示即可.,需要进行邮箱校验。

创建项目

1. 登陆成功后 , 进入个人主页 , 点击左下方的 New repository 按钮新建项目

2. 然后跳转到的新页面中输入项目名称(注意, 名称不能重复, 系统会自动校验. 校验过程可能会花费几秒钟). 校验完毕后, 点击下方的 Create repository 按钮确认创建.

3. 在创建好的项目页面中复制项目的链接, 以备接下来进行下载.

下载项目到本地

1. 复制刚才创建好的项目的链接.

2. 打开指定的需要放置项目的目录

3. 右击目录, 点击 Git Clone

4. 在弹出的对话框中输入刚才复制的项目链接即可

下载成功, 会出现绿色图标.

Git 操作的三板斧

放入代码

使用 VS 创建工程, 并把工程放在刚才下载到本地的项目路径中.

或者将曾经写过的代码的工程目录直接拷贝到项目目录中.

三板斧第一招: git add

告知 git 工具哪些文件需要进行版本管理

此时右击标记为 蓝色 ? (表示该文件未使用 git 管理) 的目录, 选择 add

弹出的对话框中勾选具体需要管理的文件. 勾选完毕点击 ok 即可.

此时图标变成红色感叹号(表示该文件被git管理, 但是未提交内容)

三板斧第二招: git commit

将修改内容提交到本地

每提交一次, 就是一个版本. 比如开发完某个功能模块, 就可以提交一次了. 后续进行版本回退都是以提交为准.

注意:此时只是提交到本地, Github 上还看不到代码变更.

右键选择 红色感叹号 目录, 选择 Git commit -> master

此时弹出了一个对话框. 可以在此处看到都需要提交哪些文件, 以及每个文件的具体改动情况. 并且需要输入提交日志. 描述这次提交的具体改动原因是什么. 这个日志是后续进行版本回退的重要参考依据.

三板斧第三招: git push

提交的内容需要同步到服务器上, 才能让其他人看到改动. 使用 push 即可.

右键需要 push 的目录, 点击 push

弹出的对话框确认 push. 不需要修改, 直接确认即可.

然后会弹出对话框提示输入 Github 的账户和密码 .

用户名密码输入正确, 点击 Login , 即可完成 push. 此时刷新 Github 的界面 , 就能看到新版本的代码了。

小结

掌握了以上 Git & Github 基本操作, 希望同学们都能够把 Github 用起来, 记录自己的学习过程, 打造自己的专属名片. 如果自己的 Github 日历能够一片绿色, 这是向面试官证明自己靠谱的最有力的证据。

希望对你有帮助!加油!

若您认为本文内容有益,请不吝赐予赞同并订阅,以便持续接收有价值的信息。衷心感谢您的关注和支持!

目录
相关文章
|
8天前
|
存储 开发工具 数据安全/隐私保护
「Mac畅玩鸿蒙与硬件9」鸿蒙开发环境配置篇9 - 使用 Git 进行版本控制
在 HarmonyOS 项目开发中,Git 版本控制可以帮助开发者规范地管理代码变更,确保协作流程顺畅。本篇将详细介绍从创建项目、提交代码到 Git 远程仓库,再到修改、推送更新的完整操作流程,重点演示如何使用 Git 和 GitHub 进行身份验证和版本管理。
37 3
「Mac畅玩鸿蒙与硬件9」鸿蒙开发环境配置篇9 - 使用 Git 进行版本控制
|
1月前
|
Linux 开发工具 git
掌握 Git:版本控制的艺术
Git 是由 Linus Torvalds 开发的分布式版本控制系统,广泛用于代码管理和团队协作。其核心价值在于分布式特性、数据完整性和支持非线性开发。本文介绍 Git 的安装、仓库初始化、文件管理、分支管理、远程仓库操作及撤销操作等基础与高级技巧,助你掌握版本控制的艺术。通过实践,你将能更高效地利用 Git 进行代码管理和团队协作。
|
10天前
|
Ubuntu 开发工具 git
Git高手必备:掌握这些版本控制最佳实践,让你的代码管理效率翻倍!
【10月更文挑战第25天】使用 Git 进行版本控制是现代软件开发的重要部分。本文详细介绍了 Git 的安装、配置、基本操作、分支管理、冲突解决及常用命令,帮助开发者提高工作效率,确保代码质量和团队协作的顺利进行。通过合理使用 Git,可以有效管理代码变更,支持多人协作,并追踪历史记录。
38 4
|
11天前
|
开发工具 C# git
C#一分钟浅谈:Git 版本控制与 GitFlow 工作流
【10月更文挑战第22天】本文介绍了 Git 和 GitFlow 的结合使用,从基础概念到具体操作,涵盖了安装配置、基本命令、GitFlow 工作流的核心分支和流程示例。同时,文章还讨论了常见的问题和易错点,如忽略文件、冲突解决、回退提交和分支命名规范,并提供了代码案例。通过学习本文,读者可以更好地理解和应用 Git 及 GitFlow,提高团队协作效率。
39 1
|
14天前
|
网络安全 开发工具 git
解决fatal:remote error:You can’t push to git://github.com/username/*.g
通过上述诊断与修复步骤,绝大多数的推送错误都能得到有效解决,确保您的Git工作流顺畅无阻。
15 1
|
10天前
|
开发工具 git 开发者
|
1月前
|
编译器 开发工具 数据安全/隐私保护
Git——多人协作/版本控制,在一个gitee仓库下开发(Gitee版教程)手把手教学,包好用的!
本文提供了一个关于如何在Gitee上进行多人协作和版本控制的详细教程,包括新建和初始化仓库、克隆仓库、邀请好友共同管理仓库以及注意事项,旨在帮助用户顺利进行代码协作开发。
116 0
Git——多人协作/版本控制,在一个gitee仓库下开发(Gitee版教程)手把手教学,包好用的!
|
2月前
|
存储 Linux 开发工具
掌握 Git:版本控制的瑞士军刀
在软件开发中,版本控制对于代码管理和团队协作至关重要。Git 是一款由 Linus Torvalds 开发的分布式版本控制系统,广泛应用于各类项目。本文介绍了 Git 的基本原理、核心概念及常用命令,如初始化仓库 (`git init`)、克隆 (`git clone`)、提交 (`git commit`) 和合并 (`git merge`) 等。此外,还分享了编写清晰提交信息、使用分支开发和定期合并等最佳实践,帮助开发者更高效地使用 Git。
|
25天前
|
Unix Shell 网络安全
git学习六:(bug总结)git@github.com: Permission denied (publickey).等
本文是关于解决在使用Git和GitHub时遇到的“git@github.com: Permission denied (publickey)”错误的指南。文章提供了详细的步骤,包括确认SSH Agent运行状态、检查密钥配置、确保密钥匹配、验证仓库URL、检查权限和代理设置,以及配置SSH文件。这些步骤帮助用户诊断并解决SSH认证问题。
65 0
|
2月前
|
测试技术 开发工具 git
掌握 Git 分支策略:提升你的版本控制技能
在现代软件开发中,版本控制至关重要,Git 作为最流行的分布式版本控制系统,其分支管理策略对于高效协作和代码维护尤为重要。本文介绍了几种常用的 Git 分支策略,包括主线开发模型、功能分支模型、Gitflow 工作流和 Forking 工作流,并探讨了如何根据项目需求选择合适的分支模型。通过保持 `master` 分支稳定、及时合并清理分支、使用命名规范、利用 Pull Request 进行代码审查及自动化测试等最佳实践,可以显著提升团队协作效率和软件质量。掌握这些策略将帮助开发者更好地管理代码库,加快开发流程。