【开发工具】认识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 。

相关推荐
不睡懒觉的橙1 小时前
【医疗大数据】医疗保健领域的大数据管理:采用挑战和影响
大数据·人工智能·信息可视化·人机交互·健康医疗
数分大拿的Statham2 小时前
PostgreSQL中的regexp_split_to_table函数详解,拆分字段为多行
大数据·数据库·postgresql·数据分析·数据清洗
码爸2 小时前
java 执行es中的sql
java·sql·elasticsearch
VaporGas2 小时前
idea集成和使用Git指南
java·git·intellij-idea
无名之逆3 小时前
计算机专业的就业方向
java·开发语言·c++·人工智能·git·考研·面试
大广-全栈开发3 小时前
centos 7 安装gitlab
linux·git·centos
zhangphil3 小时前
git删除本地分支报错:error: the branch ‘xxx‘ is not fully merged
git
howard20053 小时前
大数据时代:历史、发展与未来
大数据
翔云API3 小时前
人证合一接口:智能化身份认证的最佳选择
大数据·开发语言·node.js·ocr·php
知识分享小能手3 小时前
mysql学习教程,从入门到精通,SQL 删除数据(DELETE 语句)(19)
大数据·开发语言·数据库·sql·学习·mysql·数据开发