Git篇(2):文件的三个区域——工作区、暂存区与本地仓库

为什么需要"三个区域"?

如果你只用过一些网盘/版本控制工具,可能觉得"保存"就够了,为什么 Git 要搞三个区域?

这和开发者的实际需求有关:

  • 我可能只想提交部分文件,不是全部。
  • 我可能要分阶段保存修改,而不是"一锅端"。
  • 我可能想临时修改,但不一定要提交。

所以 Git 设计了一个"三步走"的模型:

👉 工作区 → 暂存区 → 仓库

这样就能灵活控制"哪些改动"进入历史。


三个区域的定义

1. 工作区(Working Directory)

  • 就是你电脑上能看到、能编辑的目录。
  • 文件在这里是"自由状态",你可以随便改。
  • 但是此时的改动,Git 并不知道。

2. 暂存区(Stage/Index)

  • 可以理解为"候选区"或者"快照清单"。
  • 当你执行 git add file 时,Git 会把 工作区的改动放进暂存区。
  • 暂存区决定了下一次提交的内容

3. 本地仓库(Repository,.git/objects)

  • 就是 Git 的数据库,隐藏在 .git 文件夹里。
  • 每次 git commit,Git 会把暂存区内容打包成一个快照,写进仓库。
  • 这才是真正的"历史记录"。

三个区域的关系

你可以把它类比成写书流程:

  • 工作区 = 草稿纸(你随便写)
  • 暂存区 = 出版社清单(你决定哪些草稿要出版)
  • 仓库 = 印刷好的书(成为历史,不能轻易改)

流程:

scss 复制代码
工作区 (改动) 
   │ git add
   ▼
暂存区 (候选提交)
   │ git commit
   ▼
本地仓库 (提交历史)

命令和状态

1. git status

查看三个区域的区别,常见状态:

  • Untracked(未跟踪):文件只在工作区。
  • Modified(已修改):文件被改动,但没放进暂存区。
  • Staged(已暂存):改动放在暂存区,等待提交。
  • Committed:改动已经进入仓库。

2. 举例演示

假设有个文件 a.txt

  1. 编辑文件(只在工作区)
bash 复制代码
echo "hello" >> a.txt
git status
# a.txt: modified
  1. 加入暂存区
csharp 复制代码
git add a.txt
git status
# a.txt: staged
  1. 提交到仓库
sql 复制代码
git commit -m "add hello"
git status
# nothing to commit, working tree clean

常见问题与误解

  1. 是不是每次修改都要 commit?
    不是!你可以多次 git add,最后一次 commit 一起保存。
  2. 我修改了文件,还没 add,就 commit 会怎样?
    没用!提交不会包含未加入暂存区的修改。
  3. 我 add 之后又改了文件,会怎样?
  • 暂存区保存的是 add 那一刻的快照。
  • 如果你之后又改了文件,工作区和暂存区就不一致了。
  • 需要再次 git add 才能把新的修改放进提交。

总结

  • 工作区:你改文件的地方。
  • 暂存区:下一次提交的候选清单。
  • 仓库:已经存档的历史快照。
  • 核心理解:git add = 放进候选清单,git commit = 真正写进历史。
相关推荐
电化学仪器白超7 分钟前
小乌龟Git全程图形化操作指南:嵌入式本地版本管理与Gitee私有云备份实战
git·python·单片机·嵌入式硬件·物联网·gitee·自动化
K3v3 小时前
【git】删除本地以及远端已经合并到master的分支
大数据·git·elasticsearch
云攀登者-望正茂7 小时前
将 develop 分支拉取到特性分支时解决合并污染问题
git
金銀銅鐵10 小时前
[git] 如何找到已经“丢失”的 commit?
git·后端
尘世壹俗人10 小时前
linux编译安装git
linux·运维·git
打不了嗝 ᥬ᭄1 天前
Git 原理与使用
git·gitee
m0_614619061 天前
花了一下午学 Git,整理了一份学习笔记
笔记·git·学习
AGV算法笔记1 天前
解决Git> git add -A -- fatal: CRLF would be replaced by LF in Test/Test.cpp
git
Dontla1 天前
VSCode插件Git Graph介绍(Git可视化管理分支、可视化Git)
ide·git·vscode
Echoo华地1 天前
用git diff快速比较文件夹差异并生成报告
linux·git·unix·repository·diff·branch