Git 使用指南 --- 版本管理

序言

Git 是一个开源的 分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。对一个程序员来说,掌握 Git 的使用是必要的。
 在这个系列中,将详细的介绍 Git 的使用和原理,话不多说,让我们开始吧。


1. 安装 Git

1.1 Linux — Centos

 首先你可以使用指令来查看是否已安装 Git

git

若未安装,则会显示信息:

-bash: git: command not found

可使用指令安装 Git

sudo yum -y install git

1.2 Linux — Ubuntu

 同样的,你可以使用指令来查看是否已安装 Git

git

若未安装,则会显示信息:

Command 'git' not found, but can be installed with:
sudo apt install git

可使用指令安装 Git

sudo apt install git

1.3 Windows

Windows 系统下,大家首先可以点击 Git 官网下载链接 下载 git。在安装时会有许多额外的选项,对初学者的我们来说,一路点击 next 使用默认选项就要够啦。
 现在,怎么使用呢?首先,随便点击一个文件夹,然后点击 查看更多选项,之后,如果弹出的选项中包含如下图像就说明成功安装了!
在这里插入图片描述


2. 初始化本地仓库

 创建一个本地的仓库,本质就是创建一个 进行版本控制的文件目录,要对文件进行版本控制,就必须先创建仓库。

2.1 创建本地仓库

 先进入到你想要进行版本管理的文件夹当中,使用指令 git init,即可创建一个本地仓库:
!](https://i-blog.csdnimg.cn/direct/7893354ae2c843f08498c3c924e8f7f9.png)
这里文件夹中多了一个名为 .git 的文件说明创建成功了!

2.2 初始化用户名和邮箱

 之后便是配置用户信息,你需要配置你的用户名:

git config [--global] user.name "Your_Name"

还需要配置你的邮箱:

git config [--global] user.email "Your_Email"

在这里的 [--global] 代表是一个可选项,如果加上则代表 这台机器所有的 Git 仓库 都会使用该消息配置。

 你可以使用指令来查看你所配置的信息:

git config -l

如果你想要删除相应的信息:

git config unset [--global] user.name // 删除用户名
git config unset [--global] user.email // 删除邮箱

3. 相关操作以及区域概念

 首先我们需要理解 工作区,暂存区,版本库 的概念:

  • 工作区:当我们增删改文件时,所处在的目录。
  • 暂存区:存放在 .git 目录下的 index 文件中,提供了在提交之前对更改进行组织和准备的能力
  • 版本库:⼯作区有⼀个隐藏⽬录 .git ,它不算⼯作区,⽽是 Git 的版本库。这个版本库⾥⾯的所有⽂件都可以被 Git 管理起来,每个⽂件的修改、删除都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。

这些概念现在大家看来会十分摸不着头脑,但是随着我们后面逐渐的深入,大家再来看就会有自己的理解了,但是现在大家请记住 真正进行版本管理的地方是版本库!

3.1 添加文件

 我们可以使用指令将一个或多个文件从工作区存入暂存区:

git add [file1] [file2] [file3]... // 将指定文件添加到暂存区
git add . // 将工作区所有文件添加到暂存区

 之后,我们可以使用指令将文件从暂存区存入到版本库中:

git commmit -m "Your_Msg" // 在这里,需要描述你的提交细节,帮助其他人看到更好的理解

在完成这两步之后,会显示信息:
在这里插入图片描述
一个文件被改变,插入一行内容。

3.2 删除文件

 如果我们想要删除一个版本库中的文件,首先你需要使用指令将该修改写入暂存区中:

git rm [file]

之后将删除操作提交到版本库,完成更新:

git commmit -m "Your_Msg" 

3.3 修改文件

 首先我对我的文件对多写入了一行内容,先介绍一个命令可以查看你仓库的状态(那些文件被修改后还没有添加提交):

git status

输入该指令后,我们可以看到:
在这里插入图片描述
他告诉我们 readme 这个文件被修改了,我们可以使用指令来查看工作区和暂存区的区别:

git diff [file]

这里输出的格式可能大家会觉得很奇怪:
在这里插入图片描述

这里的 - 代表的是暂存区中的内容,+ 代表的是工作区中的内容(最新的),所以
@@ -1 +1, 2 @@ 代表的是:

  • 旧内容是第一行
  • 新内容是第一行开始到第二行

之后将修改的文件上传的版本库的操作和添加文件一摸一样。


3.4 查看日志信息

 我们可以通过指令来查看我们的历史提交记录:

git log

在这里插入图片描述
可以看到这里记录所有提交的详细信息,并且每一次提交都会分配一个 commit id每一次提交都代表一个新的版本,所以这里可以理解为这是一个版本号

 你也可以添加选项让更为优雅的输出相应的信息:

git log --pretty=oneline

在这里插入图片描述

3.5 .git 文件

 在经过了上述一系列操作之后,我们再查看这个神奇的 .git 文件,我们使用指令 tree .git/ 以树状的形式查看目录:
在这里插入图片描述
我们介绍其中比较重要的几个组成部分:

  1. index:这就暂存区,我们 add 的文件都存在于此处

  2. HEAD:指向 当前正在工作的分支,默认指向 master(多分支时进一步介绍): 在这里插入图片描述
    master 又指向的是什么呢?使用 cat 指令查看一下:
    在这里插入图片描述
    一串很长的不知道是什么的序列,不知道大家还记得我们在前面讲到过一个概念commit_id,这串序列就是 commit_id,我们使用 git log 指令打印一下提交记录,查看是否存在这样一个 commit_id
    在这里插入图片描述
    不仅找到了还是第一个(最新那个),不难推断 — master 保存的就是当前最新 的 commit id

  3. objects:为 Git 的对象库,⾥⾯包含了创建的各种版本库对象及内容。当执⾏ git add 命令时,暂存区的⽬录树被更新,同时⼯作区修改(或新增)的⽂件内容被写⼊到对象库中的⼀个新的对象中,就位于 .git/objects ⽬录。


4. 版本回退

4.1 回退指令

 在开始讲解回退之前,我们想了解一个重要的指令:

git reset [--soft | --mixed | --hard] [HEAD]

回退 本质是 将版本库中的内容进⾏回退,⼯作区或暂存区是否回退由命令参数决定。

 现在我们先介绍前一个选项:
--mixed 为默认选项,使⽤时可以不⽤带该参数。该参数 将暂存区的内容退回为指定提交版本内容,⼯作区⽂件保持不变。
--soft 参数对于 ⼯作区和暂存区的内容都不变,只是将版本库回退到某个指定版本。
--hard 参数 将暂存区与⼯作区都退回到指定版本。切记⼯作区有未提交的代码时不要⽤这个命令,因为⼯作区会回滚,你没有提交的代码就再也找不回了,所以使⽤该参数前⼀定要慎重 !!!

在这里向大家举个栗子:
在这里插入图片描述
 现在我们介绍第二个参数,该参数代表我们需要回退的版本,默认 HEAD 是当前版本:

  • HEAD^ 代表上一个版本,HEAD^^ 代表上两个版本,以此类推
  • commit id 代表的就是一个版本号,可使用 commit id 回退到指定版本,使用 git log / git reflog 查看 commit id

4.2 回退场景

1. 只是修改工作区中的代码

 我完成了第一版代码,并且已经上传到版本库中了。现在我想要在第一版的基础上进行改善,但是经过改造之后原本可以正常运行的代码成功的歇菜了。
 现在我想要将我工作区的代码回退到版本一,方案一:最笨的方法就是手动删除当然极其不推荐。
 方案二:使用指令 git checkout -- [file] 将工作区的代码更新为最新提交到暂存区的文件

2. 修改的代码添加到暂存区

 现在我不小心将我的代码也添加到了暂存区中,这又改怎么回退到版本一呢?
使用指令 git reset --hard HEAD ,就可以将你的工作区和暂存区便回来啦!

3. 修改的代码提交到版本库

 这个就直接使用我们的指令 git reset --hard HEAD^,解决起来还是比较简单。

4. 回退的本质

 在 Git 内部当中,是怎么实现版本回退的呢,请看下图:
在这里插入图片描述
我们在前面介绍过 master 保存的就是当前最新的 commit id(版本),改变当前的版本,也就是改变 master 的指向。


5. 总结

 在这篇文章中我们介绍了 Git 的版本管理以及其背后的部分原理,希望大家有所收获!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/53408.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C++ 面试 - STL】每日 3 题(四)

✍个人博客:Pandaconda-CSDN博客 📣专栏地址:http://t.csdnimg.cn/fYaBd 📚专栏简介:在这个专栏中,我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话,欢迎点赞👍收藏&…

qiankun微前端

qiankun微前端踩坑指南: 上图原因子项目未启动 上图使用$tqiankun微前端中未引用i18n插件解决方案如下: 子项目main.js中加上i18n: 一些坑忘记截图复现会继续更新....... 配置正文开始------> 主项目 子项目 1.名字需要与子项目跳转后缀一致 2.v…

景联文科技:提供高质量多模态数据标注,推动智能化转型

随着人工智能技术的快速发展,多模态数据标注成为推动智能系统更深层次理解和应用的关键技术之一。 作为行业领先的多模态数据标注服务商,景联文科技凭借其在技术、流程和人才方面的综合优势,推出了全面的多模态标注解决方案,助力…

Python | Leetcode Python题解之第392题判断子序列

题目: 题解: class Solution:def isSubsequence(self, s: str, t: str) -> bool:n, m len(s), len(t)f [[0] * 26 for _ in range(m)]f.append([m] * 26)for i in range(m - 1, -1, -1):for j in range(26):f[i][j] i if ord(t[i]) j ord(a) el…

【5G PHY】5G循环前缀(CP)设计思路简述

博主未授权任何人或组织机构转载博主任何原创文章,感谢各位对原创的支持! 博主链接 本人就职于国际知名终端厂商,负责modem芯片研发。 在5G早期负责终端数据业务层、核心网相关的开发工作,目前牵头6G技术研究。 博客内容主要围绕…

将语义分割的标签转换为实例分割(yolo)的标签

语义分割的标签(目标处为255,其余处为0) 实例分割的标签(yolo.txt),描述边界的多边形顶点的归一化位置 绘制在原图类似蓝色的边框所示。 废话不多说,直接贴代码; import os import cv2 imp…

监控平台总结之面试常问答案

思路 延伸的面试题总结及答案: 1.说说前端监控平台/监控SDK架构设计和难点亮点? 架构设计 数据采集层: SDK: 在前端集成的 SDK 负责采集数据,包括性能指标、用户行为、错误日志等。 数据收集: 实现高效的数据采集机制,支持实时…

分类任务实现模型集成代码模版

分类任务实现模型(投票式)集成代码模版 简介 本实验使用上一博客的深度学习分类模型训练代码模板-CSDN博客,自定义投票式集成,手动实现模型集成(投票法)的代码。最后通过tensorboard进行可视化&#xff0…

傅里叶变换家族

禹晶、肖创柏、廖庆敏《数字图像处理(面向新工科的电工电子信息基础课程系列教材)》 禹晶、肖创柏、廖庆敏《数字图像处理》资源二维码

java设计模式(行为型模式:状态模式、观察者模式、中介者模式、迭代器模式、访问者模式、备忘录模式、解释器模式)

6,行为型模式 6.5 状态模式 6.5.1 概述 【例】通过按钮来控制一个电梯的状态,一个电梯有开门状态,关门状态,停止状态,运行状态。每一种状态改变,都有可能要根据其他状态来更新处理。例如,如果…

太细了有手就行,SpringCloud Alibaba+Nacos+Dubbo整合

SpringCloud AlibabaNacosDubbo,文末有完整项目代码链接 前言一、这几者之间关系二、准备工作1.Nacos2.SpringCloud Alibaba4.SpringCloud5.Dubbo项目中层级关系 三、代码调用逻辑1.dubbo-api模块2.account-api模块3.api-service模块4.逻辑梳理 四、Maven和配置1.pa…

尽快更新!Zyxel 路由器曝出 OS 命令注入漏洞,影响多个版本

近日,Zyxel 发布安全更新,以解决影响其多款商用路由器的关键漏洞,该漏洞可能允许未经认证的攻击者执行操作系统命令注入。 该漏洞被追踪为 CVE-2024-7261,CVSS v3 得分为 9.8,是一个输入验证故障,由用户提…

了解PD快充协议和QC快充协议

PD快充协议的实现依赖充电器与设备之间的通信协议,这种通信协议确保了充电器能够提供设备所需要的特定电压和电流。在快充技术中快充协议起到关键角色。 现在市面上最常见的快充协议有PD、QC、华为FCP/SCP、三星AFC协议 、VOOC闪充。PD和QC 协议属于公用协议 。华…

CSS 高级区块效果——WEB开发系列25

CSS提供了多种工具和属性,使我们能够创建视觉上引人注目的效果。今天我们继续将深入了解几种高级CSS效果:盒子阴影、滤镜、混合模式和文本背景裁剪,提升网页设计的质感和深度。 一、盒子阴影(Box Shadow) 对于盒子元素…

学会这2招,让你轻松提取长视频中的文案!

在当今数字化时代,短视频已成为备受欢迎的内容形式,众多品牌和营销人员借助短视频推广宣传产品。 短视频文案作为短视频内容的关键部分,能够在极短时间内向受众传达品牌信息和产品特点。 不过,短视频文案的提取和创作确实极具挑…

ceph中pg与pool关系

在Ceph中,PG(Placement Group)和Pool是非常重要的概念,它们在Ceph的存储架构中扮演着关键角色。理解这些概念有助于更好地管理和优化Ceph集群。下面详细介绍这两个概念及其相互关系。 Pool(存储池) 定义&am…

【重学 MySQL】十二、SQL 语言的规则与规范

【重学 MySQL】十二、SQL 语言的规则与规范 基本规则注释语法规则命名规则基本命名规则具体命名规范其他注意事项 数据导入指令 SQL(Structured Query Language,结构化查询语言)的规则与规范是确保SQL语句能够正确执行、提高代码可读性和可维…

【2024数模国赛赛题思路公开】国赛C题第三套思路丨无偿自提

C题参考思路 C题是一道优化问题,目的是根据题目所给的种植限制条件以及附件数据建立目标条件优化模型,优化种植策略,有利于方便田间管理,提高生产效益,减少各种不确定因素可能造成的种植风险。整个题目最重要的问题在…

Java框架第四课(对Spring的补充Spring web)

目录 一.Spring web的认识 (1)Spring Web概念 (2)Spring web的特点 (3)Springweb运行的流程 (4)Springweb运行的流程图 二.搭建Spring web 三.自定义处理器类搭建 (1)处理器类配置 (2)处理器类接受请求 (3)获得请求数据 四.拦截器 (1)关于拦截器: (2)拦截器的…

Axure中继器动态数据图表制作

在Axure RP中,中继器(Repeater)是一个非常强大的工具,它允许设计者动态地展示和交互数据,进而创建各种复杂的数据可视化图表,如柱状图、条形图、堆叠图、散点图和对比图。以下将详细介绍如何使用中继器来设…