做个小实验,帮你理解 Git 工作区与暂存区
做个小实验,帮你理解 Git 工作区与暂存区
Git 很重要,本文将通过实验的方式,带你理解 Git 的工作区、暂存区以及相关命令的使用。
1. 什么是工作区和暂存区?
在 Git 中,工作区和暂存区是两个核心概念:
- 工作区:这是你在本地仓库中实际看到的文件和目录。你可以在工作区中进行文件的新增、修改和删除操作。
- 暂存区:Git 用来准备下一次提交的区域。通过
git add 命令,你可以将工作区中的变更添加到暂存区,暂存区中的内容会作为下一次提交的内容。
2. 实验步骤
实验目标
通过实际操作,理解 Git 的工作区、暂存区以及相关命令的使用。
实验环境
- Git 已安装并配置完成
- 一个本地 Git 仓库
步骤 1:在工作区进行修改
- 打开本地 Git 仓库,创建一个新文件
test.txt,并在文件中写入一些内容。
echo "Hello, Git!" > test.txt
- 修改一个已存在的文件,例如
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 添加到暂存区
- 将
test.txt 和README.md 添加到暂存区:
git add test.txt README.md
- 再次运行
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'
- 将
README.md 从暂存区移除:
git unstage README.md
- 再次运行
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 工作区与暂存区的更多相关文章
- 理解git工作区和暂存区
版本库 在工作区目录中有一个.git文件,这个其实不是工作区而是Git的版本库 版本库中包含两个部分,一个是暂存区index/stage,另一个是git自动为我们创建的第一个分支master,以及一个 ...
- Git复习(九)之理解git工作区和暂存区
前言 Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 版本库 在工作区目录中有一个.git文件,这个其实不是工作区而是Git的版本库 版本库中包含两个部分,一个是暂存区index/ ...
- Git工作区、暂存区和版本库
基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫stage, 或index.一般存放在 ".git目录下" 下的in ...
- Git 工作区、暂存区和版本库
基本概念 我们等来理解下Git工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录 强烈推荐git新手阅读 暂存区:英文叫stage,或index.一般存放在igt 目录下的index文件( ...
- Git-Runoob:Git 工作区、暂存区和版本库
ylbtech-Git-Runoob:Git 工作区.暂存区和版本库 1.返回顶部 1. Git 工作区.暂存区和版本库 基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电 ...
- Git 工作区、暂存区和版本库、操作流程
Git 工作区.暂存区和版本库 基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫stage, 或index.一般存放在 ".g ...
- 【第四篇】-Git 工作区、暂存区和版本库之Spring Cloud直播商城 b2b2c电子商务技术总结
Git 工作区.暂存区和版本库 基本概念 我们先来理解下 Git 工作区.暂存区和版本库概念: 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫 stage 或 index.一般存放在 .git ...
- git(工作区,暂存区,管理修改,撤销修改,删除文件)
工作区和暂存区 984次阅读 Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 先来看名词解释. 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的l ...
- GIT 工作区和暂存区
工作区和暂存区 Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 先来看名词解释. 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的studygit ...
- git工作区、暂存区、版本库之间的关系
区分三者关系 Git最让你迷惑的无非是它里面的各种概念了,如果是刚开始接触Git希望看完本篇介绍之后有一个清晰的认识,笔者认识也有限这里只说说个人对使用Git的感受,说一下它里面的几个最常用的概念的理 ...
随机推荐
- 国产开源跨平台软件开发框架新选择:SOUI5
一.SOUI5跨平台解决方案的实现框架介绍 SOUI5 是一款专为跨平台客户端开发设计的国产框架,源代码:Github or Gitee, 其核心优势在于通过自主实现的 Swinx,在 Linux 平 ...
- CBR云备份与恢复管控简介
本文分享自天翼云开发者社区<CBR云备份与恢复管控简介>,作者:c****n 1.CBR云备份与恢复介绍 CBR (Cloud Backup & Restore)是一般云厂商提供的 ...
- Alink漫谈(二十一) :回归评估之源码分析
Alink漫谈(二十一) :回归评估之源码分析 0x00 摘要 Alink 是阿里巴巴基于实时计算引擎 Flink 研发的新一代机器学习算法平台,是业界首个同时支持批式算法.流式算法的机器学习平台.本 ...
- Qt数据库驱动编译(MySQL)
Qt数据库驱动编译(MySQL) 哈喽!我是 Pro_er,一名热爱编程的小伙伴.在这里我会分享一些实用的开发技巧和经验心得.如果你也对编程充满热情,欢迎关注并一起交流学习! 第一步:安装所需文件 / ...
- FLink自定义Sink,生产的数据导出到Redis
一.pom文件 https://www.cnblogs.com/robots2/p/16048648.html 二.自定义sink 2.1 自定义sink package net.xdclass.cl ...
- LangChain基础篇 (06)
LangChain 核心模块 Agent(构建复杂应用的代理系统) ReAct: Reasoning + Acting ReAct Prompt 由 few-shot task-solving tra ...
- docker - [11] 数据卷之DockerFile
通过DockerFile可以生成一个镜像 一.DockerFile的介绍 狂神:dockerfile是用来构建docker镜像的文件命令参数脚本. 狂神:dockerfile是面向开发的,我们以后要发 ...
- Flink - [01] 概述
官网:https://flink.apache.org/ 一.Flink 是什么 是一个流式的数据流执行引擎,其针对数据流的分布式计算提供了数据分布,数据通信以及容错机制等功能. 是一个框架和分布式处 ...
- C# WebClient调用WebService
WebClient调用WebService (文末下载完整代码) 先上代码: object[] inObjects = new[] { "14630, 14631" }; Http ...
- Gits-命令
Git基础命令 Git是一个分布式版本控制系统,由Linus Torvalds创建,用于有效.高速地处理从小到大的项目版本管理.以下是一些基本的Git命令和概念,它们对于使用Git进行版本控制至关重要 ...