做个小实验,帮你理解 Git 工作区与暂存区

Git 很重要,本文将通过实验的方式,带你理解 Git 的工作区、暂存区以及相关命令的使用。

1. 什么是工作区和暂存区?

在 Git 中,工作区和暂存区是两个核心概念:

  • 工作区:这是你在本地仓库中实际看到的文件和目录。你可以在工作区中进行文件的新增、修改和删除操作。
  • 暂存区:Git 用来准备下一次提交的区域。通过 git add​ 命令,你可以将工作区中的变更添加到暂存区,暂存区中的内容会作为下一次提交的内容。

2. 实验步骤

实验目标

通过实际操作,理解 Git 的工作区、暂存区以及相关命令的使用。

实验环境

  • Git 已安装并配置完成
  • 一个本地 Git 仓库

步骤 1:在工作区进行修改

  1. 打开本地 Git 仓库,创建一个新文件 test.txt​,并在文件中写入一些内容。
  echo "Hello, Git!" > test.txt
  1. 修改一个已存在的文件,例如 README.md​,添加一些内容。

步骤 2:使用 git status​ 查看状态

运行 git status​ 命令,查看当前工作区和暂存区的状态:

git status

为了简化操作,我为其定义了别名:

git config --global alias.st status

输出结果可能如下:

On branch main
Untracked files:
(use "git add <file>..." to include in what will be committed)
test.txt Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: README.md

从输出中可以看到,test.txt​ 是一个未跟踪的文件(Untracked files),​README.md​ 已被修改,但还未添加到暂存区(Changes not staged for commit)。

步骤 3:使用 git add​ 添加到暂存区

  1. test.txt​ 和 README.md​ 添加到暂存区:
git add test.txt README.md
  1. 再次运行 git st​ 查看状态:
On branch main
Changes to be committed:
(use "git restore --staged <file>..." to unstage)
new file: test.txt
modified: README.md

从输出中可以看到,test.txt​ 和 README.md​ 已被添加到暂存区(Changes to be committed)。

步骤 4:使用 git restore --staged​ 移除暂存区

为了简化操作,我为其定义了别名:

git config --global alias.unstage 'restore --staged'
  1. README.md​ 从暂存区移除:
git unstage README.md
  1. 再次运行 git st​ 查看状态:
On branch main
Changes to be committed:
(use "git restore --staged <file>..." to unstage)
new file: test.txt Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: README.md

从输出中可以看到,test.txt​ 仍然在暂存区中,README.md​ 已被移出暂存区,恢复到工作区的状态。

3. 实验总结

通过本次实验,希望你理解了 Git 的工作区和暂存区,并掌握了以下命令的使用:

  • git status​:查看工作区和暂存区的状态。
  • git add​:将工作区的变更添加到暂存区。
  • git restore --staged​:将已添加到暂存区的文件移出暂存区。

此外,我们还可以通过定义别名简化操作。掌握这些基础知识后,你可以更高效地使用 Git 进行版本控制。

下面是定义别名的汇总脚本。

git config --global alias.st status
git config --global alias.unstage 'restore --staged'

做个小实验,帮你理解 Git 工作区与暂存区的更多相关文章

  1. 理解git工作区和暂存区

    版本库 在工作区目录中有一个.git文件,这个其实不是工作区而是Git的版本库 版本库中包含两个部分,一个是暂存区index/stage,另一个是git自动为我们创建的第一个分支master,以及一个 ...

  2. Git复习(九)之理解git工作区和暂存区

    前言 Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 版本库 在工作区目录中有一个.git文件,这个其实不是工作区而是Git的版本库 版本库中包含两个部分,一个是暂存区index/ ...

  3. Git工作区、暂存区和版本库

    基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫stage, 或index.一般存放在 ".git目录下" 下的in ...

  4. Git 工作区、暂存区和版本库

    基本概念 我们等来理解下Git工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录 强烈推荐git新手阅读 暂存区:英文叫stage,或index.一般存放在igt 目录下的index文件( ...

  5. Git-Runoob:Git 工作区、暂存区和版本库

    ylbtech-Git-Runoob:Git 工作区.暂存区和版本库 1.返回顶部 1. Git 工作区.暂存区和版本库 基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电 ...

  6. Git 工作区、暂存区和版本库、操作流程

    Git 工作区.暂存区和版本库 基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫stage, 或index.一般存放在 ".g ...

  7. 【第四篇】-Git 工作区、暂存区和版本库之Spring Cloud直播商城 b2b2c电子商务技术总结

    Git 工作区.暂存区和版本库 基本概念 我们先来理解下 Git 工作区.暂存区和版本库概念: 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫 stage 或 index.一般存放在 .git  ...

  8. git(工作区,暂存区,管理修改,撤销修改,删除文件)

    工作区和暂存区 984次阅读 Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 先来看名词解释. 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的l ...

  9. GIT 工作区和暂存区

    工作区和暂存区 Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 先来看名词解释. 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的studygit ...

  10. git工作区、暂存区、版本库之间的关系

    区分三者关系 Git最让你迷惑的无非是它里面的各种概念了,如果是刚开始接触Git希望看完本篇介绍之后有一个清晰的认识,笔者认识也有限这里只说说个人对使用Git的感受,说一下它里面的几个最常用的概念的理 ...

随机推荐

  1. Spring AI 提交 PR 实战指南:避免常见坑

    今天,我们将简单地了解如何向 Spring AI 提交 PR(Pull Request).在这个过程中,有一些常见的坑需要大家注意和避免,特别是在 Git 操作方面.我们会重点关注提交信息的规范,如何 ...

  2. lagrange 插值做题记录

    插值在OI中的应用 - Grice - 博客园 lagrange 插值笔记 - 洛谷专栏 P5850 calc加强版 - 洛谷 Problem - F - Codeforces 2025oifc202 ...

  3. 闲话 4.12——对 Worpitzky 恒等式的几个证明

    \[\sum_{i}\left\langle\begin{matrix}n\\i\end{matrix}\right\rangle \binom{i+k}{n}=k^n \] 通俗的证明(具体数学的习 ...

  4. linux--安装zeppelin

    可以下载源码安装也可以用docker安装 http://zeppelin.apache.org/download.html Zeppelin 安装目录的bin文件夹下,使用以下命令启动进程: /opt ...

  5. git pull报错:Pulling without specifying how to reconcile divergent branches is discouraged.

    一.保存内容如下 二.翻译 三.设置为默认即可:git config pull.rebase false

  6. Monaco Editor 中使用在线版 Copilot

    我们是袋鼠云数栈 UED 团队,致力于打造优秀的一站式数据中台产品.我们始终保持工匠精神,探索前端道路,为社区积累并传播经验价值. 本文作者:文长 引言 现代软件开发中,代码编辑器的功能不断演进,以满 ...

  7. C#中对面向standard2.0、standard2.1的项目进行单元测试

    单元测试项目的目标框架 (TargetFramework或TargetFrameworks) 不能是standard2.0或standard2.1. 这是因为.NET Standard只是一个规范,它 ...

  8. xpath 定位单选框

    分析页面结构: 整个页面只有一组radiogroup 一个group地下存在两个radio 思路定位到页面唯一元素->下面具体radio 代码: //div[@class='el-radio-g ...

  9. nodejs 使用记录

    基本配置 不论是ubuntu还是windows10,对于非安装版的nodejs,在下载后所做的配置: 设置环境变量:NODE_ROOT为nodejs根目录,NODE_PATH为其中node_modul ...

  10. helm Error: INSTALLATION FAILED: cannot re-use a name that is still in use

    前言 使用helm安装服务报错,修改chat后重新安装报错:安装失败:无法重复使用仍在使用的名称 解决方法 1.查找安装失败的服务 helm -n {namespace} ls -a 2.删除安装失败 ...