Bootstrap

【软件入门】Git快速入门

Git快速入门

0.前言

前两天刷视频刷到Git的教学视频,才突然发现自己大学四年居然连Git都不会用,实在是太蠢了。今天也是熬到周五了,干点自己的事,囫囵吞枣地学个Git吧!

虽然发这篇博客确实是周五发的,但其实这个Flag是上上周五立的

当然了,鉴于笔者水平很差,如果想要精通Git这篇笔记是远远不够的。如果只是想用一下,我觉得看这篇笔记还是OK的。作为方便其他初学者参考的笔记,笔者尽可能详细记录,争取看了就能会。

本篇笔记参考视频:【GeekHour】一小时Git教程_哔哩哔哩_bilibili

强烈推荐如果有时间的话去看一下这位UP的视频,动画精美,内容详细,非常不错!

需要强调的是这个东西最多最多也只是一个工具,不要喧宾夺主。

1.安装和配置

进入Git官网:Git - Downloads (git-scm.com),下载自己操作系统对应的版本即可。

安装过程中需要注意的点不多。几乎可以一路默认配置,除了这里需要选择你常用的编译器:

image-20241108182004902

安装完毕后打开Git CMD(注意不是普通CMD),输入:

git -v
image-20241108182545745

能够正确显示版本号,安装成功。

安装完毕后我们配置用户名和邮箱。在命令行中先后输入下面两行代码:

git config --global user.name "xxx"
git config --global user.email "[email protected]"

这两行代码输入完毕后是没有答复的,不用担心。配置完后可以输入下面这条指令来查看是否配置成功:

git config --list
image-20241108183803843

可以看到没有问题。

2.新建版本库

版本库又名仓库,英文名Repository,简称Repo。仓库通俗来说就是目录。创建仓库有两种途径,一种是在本地创建,一种是从云端下载。

2.1.本地创建

首先需要找到一个合适的位置创建一个空目录,右键,选择Open Git Bash here

image-20241108184643890

输入:

git init
image-20241108184756030

可以看到在Git Learning目录下新建了一个.git文件夹。但是细心的朋友可能会发现文件夹是空的:

image-20241108185038339

这是因为.git文件夹是隐藏的,我们在查看中勾选显示隐藏的项目:

image-20241108185148127

这样就能看到这个文件夹了:

image-20241108185311035

不过平时不需要看到,只是在这里做演示。平时完全可以隐藏掉,这样可以防止误删。

2.2.云端下载

我们还可以通过git命令直接从Github或Gitee上下载自己或别人的仓库,在命令行输入:

git clone https://gitee.com/xxxxxxxxx
git clone https://github.com/xxxxxxxx
image-20241108190003388

稍等片刻即可。

3.版本管理

在正式开始进行版本管理之前,我们要先了解一下Git的工作区域和文件状态。这一部分强烈推荐看这段视频,一共就3分钟,这里仅放两张图。视频链接:04.工作区域和文件状态_哔哩哔哩_bilibili

image-20241108190637174

image-20241108190921604

3.1.添加和提交文件

编辑好新文件后,可以通过以下三种方式将文件添加到暂存区:

git add file1.txt
git add *.txt
git add .

第一条指令是只添加某一文件,第二条指令是将所有.txt格式的文件添加到暂存区,第三条指令是将文件夹内所有文件都添加到暂存区。

比如我们输入:

git add file1.txt

然后输入:

git status
image-20241112204353810

从上到下可以看到No commits yet,即还没有被提交到本地仓库;然后Changes to be committed,这是add到“cache”中但是还未“commit”的file1.txt;然后Untracked files,这是连add都没add的文件。

我们再输入:

git add .
git status
image-20241112204816983

可以看到都提交到暂存区了。

添加到暂存区后,需要用commit指令将暂存区里的文件提交到仓库。输入:

git commit -m log
git commit

如果用第一条,则在-m后面,即log的位置输入你本次提交留下的日志。如果用第二条,则会跳转你安装时默认的编译器。

先试试第一条:

image-20241112205109319

我们查看一下日志,输入:

git log
image-20241112205159001

我们创建三个新文件,然后重新上传到暂存区,然后试一试不加-m会发生什么。从暂存区提交到仓库之前还是先看一看状态:

image-20241112205334934

现在提交到仓库:

image-20241112205411271

稍等片刻后,自动跳转到了VSCode,这是我在安装Git时配置的默认editor。我们在光标位置输入这次的log信息,然后在最后一行输入:

:wq

注意输入的是半角冒号。

image-20241112205919030

输入完后Ctrl+s保存文件,然后直接关闭文件,终端就会自动更新:

image-20241112210035078

再看一看log:

image-20241112210113858

到这里就可以给我刚刚写的log纠错,说明在VSCode中写log并不需要输入:wq退出,而是直接保存并退出即可。

3.2.回退版本

回退版本分为3个类型,分别是soft、hard和mixed,默认的模式是mixed。

我们先在分别在file1和file2中输入(直接打开文本文件打字就行):

file1-v3
随便说点话吧
file2-v3
实在不知道说什么了哥

然后看一看状态:

image-20241112211505012

该add了:

image-20241112211532053

然后commit:

image-20241112211800910

为了便于观察,我们再在file1、2、3中分别输入:

file1-v4
没有删掉刚刚的内容哦,只是在后面又加了一句话
file2-v4
把刚刚的那些废话删了,现在只剩这一句了
file3-v4
我是纯纯的新文件

同时,新建一个file4.txt,删掉之前这三个文件:

image-20241112212205063

还是先add,然后看看status:

image-20241112212256013

可以看到它是误以为我删了俩,改名了一个,这个其实无所谓。直接commit后看log:

image-20241112212901309
3.2.1.soft模式

现在来试验一下版本回退,先试试soft模式:

git reset --soft 4e30568f302f979cde4debe02c434f9e7ce18ea5

注意,4e30568f302f979cde4debe02c434f9e7ce18ea5是v3的版本号,这个每个人的都不同,需要自己复制。

然后瞅瞅log:

image-20241112213705738

再看看file1:

image-20241112213750136

再看看status:

image-20241112213921535

可见,soft模式是回退到提交至本地仓库那一步,即回退到commit之前。

3.2.2.mixed模式

我们重新commit:

image-20241112214214249

然后输入:

git reset --mixed 4e30568f302f979cde4debe02c434f9e7ce18ea5
image-20241112223056576

然后瞅瞅log:

image-20241112223127883

再看看file1:

image-20241112223211867

再看看status:

image-20241112223322673

可见,soft模式是回退到提交至暂存区那一步,即回退到add之前。

3.2.3.hard模式

我们重新add并commit:

image-20241112223735431

然后输入:

git reset --hard 4e30568f302f979cde4debe02c434f9e7ce18ea5
image-20241112223822751

然后瞅瞅log:

image-20241112223953526

再看看file1:

image-20241112223920229

再看看status:

image-20241112224009956

可见,soft模式是回退到v3版本最初的样子,不论是文件中的内容,还是项目中包含哪些文件,都是最初的样子。

但是这时候就出现了一个问题,这些文件都没了,我后悔了该怎么办?别急,可以回溯。输入:

git reflog
image-20241112224709090

然后复制v4的版本号,输入:

git reset --hard b1e08a0

注意,这里的版本号是b1e08a0 HEAD@{1}: commit: v4这一行的版本号。

看看log:

image-20241112225210456

回溯成功了。

3.2.4.使用场景

如果你已经更新到v4,觉得v3相比于v2没什么区别,单开一个版本号太浪费了,那可以用soft或mixed模式回退到v2,然后重新commit即可。

一般不推荐使用hard,除非你百分之百确定这玩意没用了。不过即便是用了hard,文件更改没了,也不是不可挽回的,回溯就成。

3.3.查看版本差异

在文件夹内新建一个file5.txt:

image-20241121133449576

然后依次addcommit。随后我们更改一下file5.txt里的内容,在命令行中输入:

get diff
image-20241121134108115

如果我们add后再输入get diff,这个差异就不见了:

image-20241121134258927

也就是说,git diff这个命令是查看上一次commit之后,这一次add之前的差异。如果想查看上一次commit之后,这一次add之后、commit之前的差异,需要输入:

git diff HEAD
image-20241121134425240

也可以对比add前后的差异:

git diff --cached
image-20241121134739055

也可以查看不同版本的差异。我们先把这个版本commit一下:

image-20241121134944287

然后查看之前的版本号:

image-20241121135009333

我们对比v6和v5的区别,版本号分别为6fc94a042c9e8f7b73ed53fab5bbe83ed27be8e6e8dda090421cfd0f9d59ead9f976b9d79736fc54,输入:

git diff 6fc94a042c9e8f7b73ed53fab5bbe83ed27be8e6 e8dda090421cfd0f9d59ead9f976b9d79736fc54
image-20241121135210039

如果要比较某一版本和当前版本的差异,可以不输入当前版本的版本号,而是用HEAD代替,如:

git diff HEAD e8dda090421cfd0f9d59ead9f976b9d79736fc54
image-20241121135350451

更经常用的命令是比较当前版本和上一版本的差异,输入:

git diff HEAD~ HEAD
image-20241121135441801

这个命令也可以变为:

git diff HEAD~2 HEAD
image-20241121135538995

这是查看当前版本和两个版本之前版本的差异。

也可以单独查看某一个文件的差异,先整体看一下和三个版本之前的差异:

git diff HEAD~3 HEAD
image-20241121135831659

可以看到有很多文件都不同。我们输入:

git diff HEAD~3 HEAD file2.txt
image-20241121135950203

就只显示file2的差异了。

3.4.忽略文件

可以参考这篇博客:[Git 开发必备 .gitignore 详解!【建议收藏】-CSDN博客](https://blog.csdn.net/nyist_zxp/article/details/119887324?ops_request_misc=%7B%22request%5Fid%22%3A%22d4ab1f51b41cda7446b6cff986a5141f%22%2C%22scm%22%3A%2220140713.130102334…%22%7D&request_id=d4ab1f51b41cda7446b6cff986a5141f&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2alltop_positive~default-1-119887324-null-null.142v100pc_search_result_base2&utm_term=Git ignore&spm=1018.2226.3001.4187)

常用的忽略一般是忽略某个目录,一般编译产生的文件都会放在某个文件夹下,这个文件夹我们一般无需上传,将其忽略掉即可。举个例子,这是一个STM32H7项目的文件夹:

.
├─Core
│  ├─Inc
│  └─Src
├─Drivers
│  ├─CMSIS
│  │  ├─Core
│  │  │  ├─Include
│  │  │  └─Template
│  │  │      └─ARMv8-M
│  │  ├─Core_A
│  │  │  ├─Include
│  │  │  └─Source
│  │  ├─Device
│  │  │  └─ST
│  │  │      └─STM32H7xx
│  │  │          ├─Include
│  │  │          └─Source
│  │  │              └─Templates
│  │  │                  ├─arm
│  │  │                  ├─gcc
│  │  │                  └─iar
│  │  │                      └─linker
│  │  ├─docs
│  │  │  └─General
│  │  │      └─html
│  │  ├─DSP
│  │  │  ├─DSP_Lib_TestSuite
│  │  │  │  ├─Common
│  │  │  │  │  ├─inc
│  │  │  │  │  │  ├─basic_math_tests
│  │  │  │  │  │  ├─complex_math_tests
│  │  │  │  │  │  ├─controller_tests
│  │  │  │  │  │  ├─fast_math_tests
│  │  │  │  │  │  ├─filtering_tests
│  │  │  │  │  │  ├─intrinsics_tests
│  │  │  │  │  │  ├─matrix_tests
│  │  │  │  │  │  ├─statistics_tests
│  │  │  │  │  │  ├─support_tests
│  │  │  │  │  │  ├─templates
│  │  │  │  │  │  └─transform_tests
│  │  │  │  │  ├─JTest
│  │  │  │  │  │  ├─inc
│  │  │  │  │  │  │  ├─arr_desc
│  │  │  │  │  │  │  ├─opt_arg
│  │  │  │  │  │  │  └─util
│  │  │  │  │  │  └─src
│  │  │  │  │  ├─platform
│  │  │  │  │  │  ├─ARMCC
│  │  │  │  │  │  ├─ARMCLANG
│  │  │  │  │  │  └─GCC
│  │  │  │  │  └─src
│  │  │  │  │      ├─basic_math_tests
│  │  │  │  │      ├─complex_math_tests
│  │  │  │  │      ├─controller_tests
│  │  │  │  │      ├─fast_math_tests
│  │  │  │  │      ├─filtering_tests
│  │  │  │  │      ├─intrinsics_tests
│  │  │  │  │      ├─matrix_tests
│  │  │  │  │      ├─statistics_tests
│  │  │  │  │      ├─support_tests
│  │  │  │  │      └─transform_tests
│  │  │  │  ├─DspLibTest_FVP
│  │  │  │  ├─DspLibTest_FVP_A5
│  │  │  │  │  └─RTE
│  │  │  │  │      ├─CMSIS
│  │  │  │  │      └─Device
│  │  │  │  │          └─ARMCA5
│  │  │  │  ├─DspLibTest_MPS2
│  │  │  │  ├─DspLibTest_SV_FVP
│  │  │  │  ├─DspLibTest_SV_MPS2
│  │  │  │  └─RefLibs
│  │  │  │      ├─inc
│  │  │  │      └─src
│  │  │  │          ├─BasicMathFunctions
│  │  │  │          ├─ComplexMathFunctions
│  │  │  │          ├─ControllerFunctions
│  │  │  │          ├─FastMathFunctions
│  │  │  │          ├─FilteringFunctions
│  │  │  │          ├─HelperFunctions
│  │  │  │          ├─Intrinsics
│  │  │  │          ├─MatrixFunctions
│  │  │  │          ├─StatisticsFunctions
│  │  │  │          ├─SupportFunctions
│  │  │  │          └─TransformFunctions
│  │  │  ├─Examples
│  │  │  │  └─ARM
│  │  │  │      ├─arm_class_marks_example
│  │  │  │      │  └─RTE
│  │  │  │      │      └─Device
│  │  │  │      │          ├─ARMCM0
│  │  │  │      │          ├─ARMCM3
│  │  │  │      │          ├─ARMCM4_FP
│  │  │  │      │          └─ARMCM7_SP
│  │  │  │      ├─arm_convolution_example
│  │  │  │      │  └─RTE
│  │  │  │      │      └─Device
│  │  │  │      │          ├─ARMCM0
│  │  │  │      │          ├─ARMCM3
│  │  │  │      │          ├─ARMCM4_FP
│  │  │  │      │          └─ARMCM7_SP
│  │  │  │      ├─arm_dotproduct_example
│  │  │  │      │  └─RTE
│  │  │  │      │      └─Device
│  │  │  │      │          ├─ARMCM0
│  │  │  │      │          ├─ARMCM3
│  │  │  │      │          ├─ARMCM4_FP
│  │  │  │      │          └─ARMCM7_SP
│  │  │  │      ├─arm_fft_bin_example
│  │  │  │      │  └─RTE
│  │  │  │      │      └─Device
│  │  │  │      │          ├─ARMCM0
│  │  │  │      │          ├─ARMCM3
│  │  │  │      │          ├─ARMCM4_FP
│  │  │  │      │          └─ARMCM7_SP
│  │  │  │      ├─arm_fir_example
│  │  │  │      │  └─RTE
│  │  │  │      │      └─Device
│  │  │  │      │          ├─ARMCM0
│  │  │  │      │          ├─ARMCM3
│  │  │  │      │          ├─ARMCM4_FP
│  │  │  │      │          └─ARMCM7_SP
│  │  │  │      ├─arm_graphic_equalizer_example
│  │  │  │      │  └─RTE
│  │  │  │      │      └─Device
│  │  │  │      │          ├─ARMCM0
│  │  │  │      │          ├─ARMCM3
│  │  │  │      │          ├─ARMCM4_FP
│  │  │  │      │          └─ARMCM7_SP
│  │  │  │      ├─arm_linear_interp_example
│  │  │  │      │  └─RTE
│  │  │  │      │      └─Device
│  │  │  │      │          ├─ARMCM0
│  │  │  │      │          ├─ARMCM3
│  │  │  │      │          ├─ARMCM4_FP
│  │  │  │      │          └─ARMCM7_SP
│  │  │  │      ├─arm_matrix_example
│  │  │  │      │  └─RTE
│  │  │  │      │      └─Device
│  │  │  │      │          ├─ARMCM0
│  │  │  │      │          ├─ARMCM3
│  │  │  │      │          ├─ARMCM4_FP
│  │  │  │      │          └─ARMCM7_SP
│  │  │  │      ├─arm_signal_converge_example
│  │  │  │      │  └─RTE
│  │  │  │      │      └─Device
│  │  │  │      │          ├─ARMCM0
│  │  │  │      │          ├─ARMCM3
│  │  │  │      │          ├─ARMCM4_FP
│  │  │  │      │          └─ARMCM7_SP
│  │  │  │      ├─arm_sin_cos_example
│  │  │  │      │  └─RTE
│  │  │  │      │      └─Device
│  │  │  │      │          ├─ARMCM0
│  │  │  │      │          ├─ARMCM3
│  │  │  │      │          ├─ARMCM4_FP
│  │  │  │      │          └─ARMCM7_SP
│  │  │  │      ├─arm_variance_example
│  │  │  │      │  └─RTE
│  │  │  │      │      └─Device
│  │  │  │      │          ├─ARMCM0
│  │  │  │      │          ├─ARMCM3
│  │  │  │      │          ├─ARMCM4_FP
│  │  │  │      │          └─ARMCM7_SP
│  │  │  │      └─boot
│  │  │  ├─Include
│  │  │  ├─Lib
│  │  │  │  ├─ARM
│  │  │  │  ├─GCC
│  │  │  │  └─IAR
│  │  │  ├─PythonWrapper
│  │  │  │  └─cmsisdsp_pkg
│  │  │  │      └─src
│  │  │  └─Source
│  │  │      ├─BasicMathFunctions
│  │  │      ├─CommonTables
│  │  │      ├─ComplexMathFunctions
│  │  │      ├─ControllerFunctions
│  │  │      ├─FastMathFunctions
│  │  │      ├─FilteringFunctions
│  │  │      ├─MatrixFunctions
│  │  │      ├─StatisticsFunctions
│  │  │      ├─SupportFunctions
│  │  │      └─TransformFunctions
│  │  ├─Include
│  │  ├─NN
│  │  │  ├─Examples
│  │  │  │  ├─ARM
│  │  │  │  │  └─arm_nn_examples
│  │  │  │  │      ├─cifar10
│  │  │  │  │      │  └─RTE
│  │  │  │  │      │      ├─Compiler
│  │  │  │  │      │      ├─Device
│  │  │  │  │      │      │  ├─ARMCM0
│  │  │  │  │      │      │  ├─ARMCM3
│  │  │  │  │      │      │  ├─ARMCM4_FP
│  │  │  │  │      │      │  └─ARMCM7_SP
│  │  │  │  │      │      ├─_ARMCM0
│  │  │  │  │      │      ├─_ARMCM3
│  │  │  │  │      │      ├─_ARMCM4_FP
│  │  │  │  │      │      └─_ARMCM7_SP
│  │  │  │  │      └─gru
│  │  │  │  │          └─RTE
│  │  │  │  │              ├─Compiler
│  │  │  │  │              ├─Device
│  │  │  │  │              │  ├─ARMCM0
│  │  │  │  │              │  ├─ARMCM3
│  │  │  │  │              │  ├─ARMCM4_FP
│  │  │  │  │              │  └─ARMCM7_SP
│  │  │  │  │              ├─_ARMCM0
│  │  │  │  │              ├─_ARMCM3
│  │  │  │  │              ├─_ARMCM4_FP
│  │  │  │  │              └─_ARMCM7_SP
│  │  │  │  └─IAR
│  │  │  │      └─iar_nn_examples
│  │  │  │          ├─NN-example-cifar10
│  │  │  │          └─NN-example-gru
│  │  │  ├─Include
│  │  │  ├─NN_Lib_Tests
│  │  │  │  └─nn_test
│  │  │  │      ├─Ref_Implementations
│  │  │  │      └─RTE
│  │  │  │          ├─Device
│  │  │  │          │  ├─ARMCM0
│  │  │  │          │  ├─ARMCM3
│  │  │  │          │  ├─ARMCM4
│  │  │  │          │  ├─ARMCM4_FP
│  │  │  │          │  ├─ARMCM7_SP
│  │  │  │          │  └─STM32F411RETx
│  │  │  │          ├─_ARMCM0
│  │  │  │          ├─_ARMCM3
│  │  │  │          ├─_ARMCM4_FP
│  │  │  │          └─_ARMCM7_SP
│  │  │  └─Source
│  │  │      ├─ActivationFunctions
│  │  │      ├─ConvolutionFunctions
│  │  │      ├─FullyConnectedFunctions
│  │  │      ├─NNSupportFunctions
│  │  │      ├─PoolingFunctions
│  │  │      └─SoftmaxFunctions
│  │  ├─RTOS
│  │  │  └─Template
│  │  └─RTOS2
│  │      ├─Include
│  │      ├─Source
│  │      └─Template
│  └─STM32H7xx_HAL_Driver
│      ├─Inc
│      │  └─Legacy
│      └─Src
├─Function
└─MDK-ARM
    ├─DebugConfig
    ├─RTE
    │  └─_Test1.0.0
    └─Test1.0.0

假设我们需要忽略Drivers文件夹和MDK-ARM中的RTE文件夹,我们应该如何操作呢?输入:

vi .gitignore
image-20241121142705993

然后输入:

Drivers/
MDK-ARM/RTE/
image-20241121143244272

然后按Esc,输入:wq

image-20241121143602443

即可退出。

看一下状态:

image-20241121143640504

可以看到并没有显示Drivers文件夹。

4.云端配置

4.1.Github

自行创建Github账号。

4.1.1.SSH配置

进入GitHub,创建自己的仓库:

image-20241121151528819

配置如下(注意不要勾选其他内容,否则不会显示引导界面):

image-20241121152240979

然后会进入一个引导界面:

image-20241121160531064

打开Git Bash终端,然后先后输入:

cd
ssh-keygen -t rsa -b 4096
image-20241121154832990

然后需要手动输入一个名称,这个可以直接回车让他自动生成,需要连续回车三下:

image-20241121154944619

然后先后输入:

cd .ssh
ls -ltr
image-20241121155208795

没有后缀的是私钥文件,谁也不要给;有后缀的是公钥文件。输入:

vi id_rsa.pub
image-20241121155604083

复制内容:

ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDQiflzS5ow+......PRv86w== Fangzhou Tan@LAPTOP-JQFPEMOQ

回到Github,点击头像,找到Settings:

image-20241121155656706

然后找到SSH配置:

image-20241121155734582

image-20241121155913900

名字是任意的,想是啥就是啥,不用和仓库名一样。

设置好后在引导界面复制SSH:

image-20241121160611652

到本地的文件夹,打开git bash终端,然后输入(注意在输入前要关闭代理):

git clone [email protected]:LengYuuu/Hello_Github.git
image-20241121160645511

需要手动输入yes,即可完成克隆。如下所示:

image-20241121160729308

在文件夹中加点文件:

image-20241121161000294

然后在中断中先后输入:

git add .
git commit -m "first commit"
git push
image-20241121161658945

去Github刷新一下:

image-20241121161725553

成功上传!

4.1.2.关联本地仓库和远程仓库

写不动了实在是,后面再补吧

4.2.Gitee

和Github几乎一样。

4.3.GitLab

私有化部署

暂时不需要私有化部署,也是先挖坑吧。

5.在VSCode中使用Git

5.1.配置Git

如果按照刚刚的步骤下载Git,但是打开VSCode,显示:

image-20241121170434097

那可能是Git的环境变量没有配好。在环境变量中加入:

image-20241121170547883

然后在命令行中检查一下:

image-20241121170631289

重启VSCode:

image-20241121170704922

如果还是没有找到Git,则点击文件 -> 首选项 -> 设置,搜索 git.path

image-20241121171007819

image-20241121170946768

然后手动设置 Git 的完整路径,例如:

json
"git.path": "C:\\Program Files\\Git\\bin\\git.exe"

然后保存,重启VSCode即可。


未完待续…
先把学完的部分发出来,后面慢慢学慢慢补齐

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;