【开发工具】认识Git | 认识工作区、暂存区、版本库

文章目录

一、Git初识

git本质上是一个版本控制器

为了能够更方便我们管理不同版本的文件,便有了版本控制器。所谓的版本控制器,就是能让你了解到一个文件的历史,以及它的发展过程的系统。通俗的讲就是一个可以记录工程的每一次改动和版本迭代的一个管理系统,同时也方便多人协同作业。

目前最主流的版本控制器就是 Git 。Git 可以控制电脑上所有格式的文件,例如 doc、excel、dwg、dgn、rvt等等。对于我们开发人员来说,Git 最重要的就是可以帮助我们管理软件开发项目中的源代码文件!

二、Git的安装 - CentOS

安装 Git:

bash 复制代码
sudo yum -y install git

查看git的版本:

bash 复制代码
git --version

三、Git基本操作

1. 创建Git本地仓库

创建一个 Git 本地仓库对应的命令为 git init ,注意命令要在文件目录下执行,例如:

bash 复制代码
hyb@139-159-150-152:~/gitcode$ pwd
/home/hyb/gitcode
hyb@139-159-150-152:~/gitcode$ git init
Initialized empty Git repository in /home/hyb/gitcode/.git/
hyb@139-159-150-152:~/gitcode$ ll -a
total 12
drwxrwxr-x 3 hyb hyb 4096 May 5 15:49 ./
drwxr-xr-x 13 hyb hyb 4096 May 5 15:47 ../
drwxrwxr-x 7 hyb hyb 4096 May 5 15:49 .git/

2. 配置Git

当安装 Git 后首先要做的事情是设置你的 用户名称 和 e-mail 地址,这是非常重要的。配置命令为:

bash 复制代码
git config [--global] user.name "Your Name"
git config [--global] user.email "email@example.com"
# 把 Your Name 改成你的昵称
# 把 email@example.com 改成邮箱的格式,只要格式正确即可。

3. 认识工作区、暂存区、版本库

  • 工作区:是在电脑上你要写代码或文件的目录。
  • 暂存区:英文叫 stage 或 index。一般存放在 .git 目录下的 index 文件(.git/index)中,我们把暂存区有时也叫作索引(index)。
  • 版本库:又名仓库,英文名 repository 。工作区有一个隐藏目录 .git ,它不算工作区,而是 Git 的版本库。这个版本库里面的所有文件都可以被 Git 管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以"还原"。

下面这个图展示了工作区、暂存区和版本库之间的关系:

• 图中左侧为工作区,右侧为版本库。Git 的版本库里存了很多东西,其中最重要的就是暂存区。

• 在创建 Git 版本库时,Git 会为我们自动创建一个唯一的 master 分支,以及指向 master 的一个指针叫 HEAD。(分支和HEAD的概念后面再说)

• 当对工作区修改(或新增)的文件执行 git add 命令时,暂存区目录树的文件索引会被更新。

• 当执行提交操作git commit 时,master 分支会做相应的更新,可以简单理解为暂存区的目录

树才会被真正写到版本库中。

4. 版本回退

执行 git reset 命令用于回退版本,可以指定退回某一次提交的版本。要解释一下"回退"本质是要将版本库中的内容进行回退,工作区或暂存区是否回退由命令参数决定:
git reset 命令语法格式为:

bash 复制代码
git reset [--soft | --mixed | --hard] [HEAD]

• --mixed 为默认选项,使用时可以不用带该参数。该参数将暂存区的内容退回为指定提交版本内

容,工作区文件保持不变。

• --soft 参数对于工作区和暂存区的内容都不变,只是将版本库回退到某个指定版本。

• --hard 参数将暂存区与工作区都退回到指定版本。切记工作区有未提交的代码时不要用这个命

令,因为工作区会回滚,你没有提交的代码就再也找不回了,所以使用该参数前一定要慎重。

• HEAD 说明:

◦ 可直接写成 commit id,表示指定退回的版本

◦ HEAD 表示当前版本

◦ HEAD^ 上一个版本

◦ HEAD^^ 上上一个版本

◦ 以此类推...

• 可以使用 ~数字表示:

◦ HEAD~0 表示当前版本

◦ HEAD~1 上一个版本

◦ HEAD^2 上上一个版本

◦ 以此类推...

为了便于表述,方便测试回退功能,我们先做一些准备工作:更新3个版本的 ReadMe,并分别进行3次提交,如下所示:

5. 撤销修改

情况1:对于工作区的代码,还没有add

  1. 直接删除代码

  2. 使用:

    bash 复制代码
    git checkout -- [filename]

情况二:已经add ,但没有commit

git reset 回退命令,该命令如果使用 --mixed 参数,可以将暂存区

的内容退回为指定的版本内容,但工作区文件保持不变。

bash 复制代码
git reset --mixed HEAD ReadMe

这样以后就变成了情况一了,可以继续使用 git checkout -- 来丢弃工作区的修改。

情况三:已经add ,并且也commit 了

前提:还没有push到远端仓库

我们可以 git reset --hard HEAD^ 回退到上一个版本。不过,这是有条件的,就是

你还没有把自己的本地版本库推送到远程。

删除文件

bash 复制代码
rm

rm命令只会删除工作区的文件,对于暂存区和版本库中的内容没有影响。

一般删除文件,有两种可能:

• 确实要从版本库中删除该文件

• 不小心删错了 - git checkout -- filename恢复工作区文件

对于第一种情况,很明显是没有删完,我们只删除了工作区的文件。这时就需要使用 git rm 将文

件从暂存区和工作区中删除,并且 commit 。

相关推荐
武子康5 分钟前
大数据-212 数据挖掘 机器学习理论 - 无监督学习算法 KMeans 基本原理 簇内误差平方和
大数据·人工智能·学习·算法·机器学习·数据挖掘
lzhlizihang1 小时前
【Hive sql 面试题】求出各类型专利top 10申请人,以及对应的专利申请数(难)
大数据·hive·sql·面试题
Tianyanxiao1 小时前
如何利用探商宝精准营销,抓住行业机遇——以AI技术与大数据推动企业信息精准筛选
大数据·人工智能·科技·数据分析·深度优先·零售
大数据编程之光1 小时前
Hive 查询各类型专利 top10 申请人及专利申请数
大数据·数据仓库·hive·hadoop
binishuaio1 小时前
Java 第11天 (git版本控制器基础用法)
java·开发语言·git
GDDGHS_2 小时前
大数据工具 flume 的安装配置与使用 (详细版)
大数据·flume
会发光的猪。2 小时前
如何在vscode中安装git详细新手教程
前端·ide·git·vscode
Acrelhuang3 小时前
安科瑞5G基站直流叠光监控系统-安科瑞黄安南
大数据·数据库·数据仓库·物联网
皓7413 小时前
服饰电商行业知识管理的创新实践与知识中台的重要性
大数据·人工智能·科技·数据分析·零售
Mephisto.java3 小时前
【大数据学习 | kafka高级部分】kafka的kraft集群
大数据·sql·oracle·kafka·json·hbase