初学者都能懂得 Git 说明

本文写于 2020 年 8 月 10 日

网上有很多非常优秀的 Git 教程,但是他们都是面向有一定基础的开发者的。

可是对于没什么基础的初学者甚至是偶尔操作代码的设计师而言,Git 也是必须掌握的技能!

注意,这不是一个教程,而是一个说明,仅仅针对初学者和设计师或其他不太懂代码却需要一点点 Git 基础概念的人。

什么是 Git?

Git 是一个免费的、开源的代码版本控制系统。

什么意思呢?免费开源好理解,就是不要钱嘛。那什么叫版本控制系统?

所谓版本控制,就是当你修改文件之后,你可以让 Git 记住目前的文件内容为一个版本,并且对该版本进行语言描述;当你下一次修改完成,你又可以让 Git 记住当前的文件内容,这又是一个版本,再对对该版本进行语言描述。

而 Git 的强大就在于,他会记录下你两次版本之间进行的修改,例如你删除了哪些字符,都会被 Git 所记录下来。然后你就可以利用 Git 让自己的文件,变回之前的任意一个版本了!

总而言之,可以理解为,Git 就是关于项目文件中历史版本的注释的集合,以及变化的历史记录。

你是否需要学习 Git?

问自己几个问题吧:

  • 你是否曾经尝试过与其他人同时处理一个项目?
  • 你是否曾经希望可以将工作回滚到以前的某个版本?
  • 你是否想了解开发人员为何进行某些更改?

如果你想解决这些问题,那么就学习 Git 吧。

Git 第零步

下载并且安装一个 Git。(网上有太多手把手的教程,此处就不赘述如何安装了)

新建一个文件夹,将你的终端(或是 CMD 或是 PowerShell 或是 Bash 或是 Zsh)切换到该文件夹下。

然后输入:git init。这是我们小学二年级就学过的英语:初始化 git

Git 第一步:新建一个文件

对于一个项目,我们通常会新建一个 README.md 文件来向其他开发者简单阐述我们的这个项目。(md 文件是 markdown 文件,一般用于写作,不必深究其中符号的意义)

# 我的 Git 学习项目

在这个项目中,我将会学习 `git` 的各种用法。

如果你此时使用的是 VSCode 或是其他有图形化 Git 界面的软件,你会看到 Git 的图标出现了一个小小的提示。但是我们不急着去使用图形界面,因为图形界面每家都不同,可是命令行里对 Git 的操作是不会变的,哪些图形界面也只是帮你操作了命令行而已。

Git 第二步:收集更改

我们刚刚新建了一个文件,对他新增了内容。对于我们整个项目中,这其实算是一次更改:我们从无文件,更改为了拥有一个 README.md 文件。然后将没有内容的文件,新增了这三行几十个字符。

接下来我们就可以通过 git add 的命令,来收集我们的更改。

git add README.md 翻译成中文就是 git 来帮我添加一下 README.md 文件

完成后是不是没有任何的提示?这就对了。Unix 的哲学是“没有消息就是好消息”

这个时候我们有一个疑惑,add 既然是添加,那会把我的添加到哪里呢?

这里添加的位置叫做暂存区。你将暂存区可以理解为一个没有关上的快递盒子。

如果我们有需要,随时可以把里面的东西拿出来,或者换成其他的东西,或者放更多的东西进去。

Git 第三步:打包更改

接下来我们要使用 git commit 命令了,它是为了将我们暂存的文件,作为一个版本,并且作出说明后,进行保存与管理。

git commit -m "新增了 README 文件",翻译成中文就是 git 帮我提交一下现在的代码,这次提交我的备注是“新增了 README 文件”

刚刚说过了,我们 git add 相当于把东西收纳到没有关上的快递盒子里,git commit 就相当于把这个快递盒子给打包好,然后贴上快递信息。

这个信息非常重要,刚刚的 -m 就是 message 的意思。我希望任何时候你都要写这份“快递信息”——如果不想写,是有办法的,但是我不会教给你。

现在我们回顾一下刚刚的操作。

首先我们通过 add 命令,将我们作出修改的文件添加到了暂存区;然后通过 commit 命令将其打包,存为了一个版本。Git 会帮助我们记住这个版本与前一个版本之间进行的所有修改。

Git 第四步:分享您的修改

使用 git push 可以将你的项目上传到远端的仓库中。

我们通常可以使用 GitHub 或者码云。在这两个网站新建账号后,我们可以新建一个仓库,新建完成后,会出现文字提示来告诉我们如何绑定远端和本地。所以在此就不赘述了。

从此以后,我们每次做完修改,都可以先提交到暂存区,然后 commit 打包,最后 git push 到远端仓库。这样远端仓库就会和本地一样,记录我们的每一次打包。

Git 第五步:获取最新的修改

通常我们使用远端仓库是为了和他人协同开发。

那么如果别人对仓库进行了修改,我们的本地仓库会变嘛?

不会的,所以我们需要获取最新的更新:git pull

在开始工作之前和在 push 更改之前,对项目进行 git pull 是一个好习惯,如果出现了任何冲突都可以及时的进行解决。

PS:和他人协同开发时,如果出现冲突,一定不可以无视冲突,强行上传。请务必解决!

下一回,Git 分支与协作

(完)

初学者都能懂得 Git 说明的更多相关文章

  1. Git 初学者使用指南及Git 资源整理

    Git 资源整理 Git is a free and open source distributed version control system designed to handle everyth ...

  2. 天天都在用Git,那么你系统学习过吗?(一)学习过程

    你系统学习Git了吗? 使用Mac编程的好处,不是因为Mac长得好看 Git内容学习准备 如果你还没有用Git,就不要写代码了. GitHub仓库的使用. 新员工入职的时候,会让他先用一周的时间去学习 ...

  3. 初学者都在坑里!不要在Python中使用“+”来连接字符串

    很多初学者都像我一样,最开始使用Python时,会不自觉地使用“+”来连接字符串,就像在许多其他编程语言(比如Java)中那样,因为这样既直观又容易. 但我很快意识到成熟的开发人员似乎更喜欢使用.jo ...

  4. GIT学习——天天都在用Git,那么你系统学习过吗?(学习过程)

    你系统学习Git了吗? 学习圣思园张龙老师的Git课程. 使用Mac编程的好处,不是因为Mac长得好看 Git内容学习准备 如果你还没有用Git,就不要写代码了. GitHub仓库的使用. 新员工入职 ...

  5. 初学者最易懂的git教程在这里!

    一.git简介: Linux创建了Linux,但是Linux的发展壮大是由世界各地的热心志愿者参与编写的?那么那么多份的代码是怎么合并的呢?之前是在2002年以前,世界各地的志愿者把源代码文件通过di ...

  6. 每个java初学者都应该搞懂的问题

    对于这个系列里的问题,每个学JAVA的人都应该搞懂.当然,如果只是学JAVA玩玩就无所谓了.如果你认为自己已经超越初学者了,却不很懂这些问题,请将你自己重归初学者行列.内容均来自于CSDN的经典老贴. ...

  7. 怒肝俩月,新鲜出炉史上最有趣的Java小白手册,第一版,每个 Java 初学者都应该收藏

    这么说吧,在我眼里,Java 就是最流行的编程语言,没有之一(PHP 往一边站).不仅岗位多,容易找到工作,关键是薪资水平也到位,不学 Java 亏得慌,对吧? 那可能零基础学编程的小伙伴就会头疼了, ...

  8. PHP初学者都该掌握哪些技能

    初学PHP时,不要好高骛远,脚踏实地的把LNMP搞熟练,打好基础再往更高的层次发展.今天给大家总结初学者应该学会的技能. 1.Linux 基本命令.操作.启动.基本服务配置(包括rpm安装文件,各种服 ...

  9. Java初学者都必须理解的六大问题 (整理自网络)

    问题一:我声明了什么! 1. String s = "Helloworld!"; 许多人都做过这样的事情,但是,我们到底声明了什么?回答通常是:一个String,内容是“Hello ...

随机推荐

  1. 决策树算法一:hunt算法,信息增益(ID3)

    决策树入门 决策树是分类算法中最重要的算法,重点 决策树算法在电信营业中怎么工作? 这个工人也是流失的,在外网转移比处虽然没有特征来判断,但是在此节点处流失率有三个分支概率更大 为什么叫决策树? 因为 ...

  2. 【静态页面架构】CSS之链接和图像

    CSS架构 一.链接: 链接元素:通过使用a元素的href属性设置跳转到指定页面地址 <style> a{ color: blue; text-decoration: none; } a: ...

  3. JavaScript正则进阶之路——活学妙用奇淫正则表达式

    原文收录在我的 GitHub博客 (https://github.com/jawil/blog) ,喜欢的可以关注最新动态,大家一起多交流学习,共同进步,以学习者的身份写博客,记录点滴. 有些童鞋肯定 ...

  4. 记一次用mpvue框架搭建的小程序

    介绍 mpvue (github 地址请参见)是一个使用 Vue.js 开发小程序的前端框架.框架基于 Vue.js 核心,mpvue 修改了Vue.js 的 runtime 和 compiler 实 ...

  5. 【Android开发】View 转 Bitmap

    public static Bitmap loadBitmapFromView(View v) { int w = v.getWidth(); int h = v.getHeight(); Bitma ...

  6. java中封装encapsulate的概念

    封装encapsulate的概念:就是把一部分属性和方法非公有化,从而控制谁可以访问他们. https://blog.csdn.net/qq_44639795/article/details/1018 ...

  7. script标签中defer和async的区别(稀土掘金学习)

    如果没有defer或async属性,浏览器会立即加载并执行相应的脚本.它不会等待后续加载的文档元素,读取到就会开始加载和执行,这样就阻塞了后续文档的加载. 下图可以直观的看出三者之间的区别: 其中蓝色 ...

  8. 关于#pragma 和 _pragma

    首先要明确 #pragma 和_Pragma 是什么 这两个都是出自于c/c++ 的 ,其中#pragma 是预处理指令(preProcess directive ) ,#pragma是用来向编译器传 ...

  9. Python入门-面向对象三大特性-多态

    Pyhon不支持多态并且也用不到多态,多态的概念是应用于Java和C#这一类强类型语言中,而Python崇尚"鸭子类型".

  10. SpringMVC获取请求参数-POJO类型参数

    1.Controller中的业务方法的POJO参数的属性名与请求参数一致,参数值会自动映射匹配 1.创建POJO类 public class User { private String usernam ...