【git】工作场景下的 工作区 <-> 暂存区<-> 本地仓库 命令实战 具体案例

news/2025/2/22 0:47:43

🚀 Git 工作区 → 暂存区 → 本地仓库 → 回退实战

Git 的核心流程是:
👉 工作区(Working Directory)git add暂存区(Staging Area)git commit本地仓库(Local Repository)
如果想回退,可以从本地仓库 → 暂存区 → 工作区
在这里插入图片描述


📌 1. 创建一个 Git 仓库

mkdir my_project && cd my_project
git init  # 初始化 Git 仓库

git init 会创建一个 .git 目录,用于管理 Git 版本控制信息。


📌 2. 创建一个文件(工作区)

echo "Hello Git!" > hello.txt

此时,hello.txt工作区,但 Git 还不知道它的存在。

查看状态:

git status

输出:

Untracked files:
  (use "git add <file>..." to include in what will be committed)
        hello.txt

Git 发现 hello.txt,但它还没有被跟踪。


📌 3. 添加到暂存区

git add hello.txt

再次查看状态:

git status

输出:

Changes to be committed:
  (use "git rm --cached <file>..." to unstage)
        new file:   hello.txt

hello.txt 进入了暂存区,但还没有提交到本地仓库。


📌 4. 提交到本地仓库

git commit -m "初次提交"

输出:

[main (root-commit) 1a2b3c4] 初次提交
 1 file changed, 1 insertion(+)
 create mode 100644 hello.txt

hello.txt 现在存储到了本地仓库,Git 记录了它的快照。


📌 5. 修改文件并回退

(1) 修改 hello.txt
echo "Git is awesome!" >> hello.txt

查看状态:

git status

输出:

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:   hello.txt

hello.txt工作区被修改了。

(2) 回退修改

如果不想要这次修改:

git restore hello.txt

再次 git status

nothing to commit, working tree clean

hello.txt 回到了本地仓库的版本

(3) 误 add 了,如何回退?
git add hello.txt  # 错误地加入暂存区
git restore --staged hello.txt  # 从暂存区撤回到工作区

这样 hello.txt 又变回未 add 之前的状态。
即:
在没有commit之前,想要回退修改都是用git restore

  • 撤销修改git restore <file>
  • 撤销 addgit restore --staged <file>
(4) 误 commit 了,如何回退?

如果误提交到本地仓库:

git reset --soft HEAD~1  # 退回到暂存区 也可以用git log显示出所有提交记录,
# 复制想要回到的commit id 使用git reset --soft <commit id> 这里HEAD~1表示回退到上一个commit状态
git reset HEAD  # 退回到工作区

这样就撤回了 commit,但代码不会丢失。

commit之后的回退,都是用git reset

在这里插入图片描述


📌 6. 总结:Git 各区域操作

操作命令
工作区 → 暂存区git add <file>
暂存区 → 本地仓库git commit -m "提交信息"
本地仓库 → 暂存区(撤回提交)git reset --soft HEAD~1
暂存区 → 工作区(撤回 addgit restore --staged <file>
工作区回退(撤销修改)git restore <file>

git_reset_HEAD__git_restore_staged__138">** git reset HEADgit restore --staged 的区别**

命令作用影响的区域适用场景
git reset HEAD取消所有已暂存的修改撤销暂存区(但保留工作区的修改)取消 git add .
git restore --staged file.txt取消某个文件的 git add撤销暂存区(但不影响工作区)取消某个文件的 git add
git restore file.txt还原工作区文件丢弃未暂存的修改,让文件回到 HEAD 版本撤销误改的文件

总结:

  • git reset HEAD 作用于 整个暂存区,适合批量撤销 git add
  • git restore --staged file.txt 只作用于 单个文件,适合撤销特定文件的 git add

Git实战:

案例:开发一个简单的登录功能

假设你正在开发一个网站的登录功能,你需要修改以下文件:

  • index.html: 添加登录表单
  • style.css: 添加登录表单的样式
  • script.js: 添加登录表单的验证逻辑

一、准备工作

  1. 克隆远程仓库:假设你已经克隆了公司项目的代码仓库到本地。
  2. 创建开发分支:从主分支 (main) 创建一个新的分支 feature/login,并切换到该分支。
git checkout -b feature/login

二、开发登录功能

  1. 修改代码:在 index.htmlstyle.cssscript.js 文件中进行代码编写和修改。
  2. 查看工作区状态:使用 git status 命令查看工作区中哪些文件被修改了。
git status
  • 你会看到类似以下的输出:
On branch feature/login
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:   index.html
	modified:   style.css
	modified:   script.js

no changes added to commit (use "git add" and/or "git commit -a")
  • 这表示 index.htmlstyle.cssscript.js 文件被修改了,但还没有添加到暂存区。

三、将修改添加到暂存区

  1. 添加文件到暂存区:使用 git add 命令将修改后的文件添加到暂存区。
git add index.html style.css script.js
  • 也可以使用 git add . 添加所有修改过的文件。
  1. 再次查看工作区状态:使用 git status 命令查看工作区状态。
git status
  • 你会看到类似以下的输出:
On branch feature/login
Changes to be committed:
  (use "git restore --staged <file>..." to unstage)
	modified:   index.html
	modified:   style.css
	modified:   script.js
  • 这表示 index.htmlstyle.cssscript.js 文件已经被添加到暂存区,准备提交到本地仓库。

四、将修改提交到本地仓库

  1. 提交代码:使用 git commit 命令将暂存区的文件提交到本地仓库。
git commit -m "完成登录功能开发"
  • 提交信息应该简洁明了,描述这次提交的内容。
  1. 查看提交历史:使用 git log 命令查看提交历史。
git log
  • 你会看到类似以下的输出:
commit 1234567890abcdef1234567890abcdef12345678 (HEAD -> feature/login)
Author: yourname <yourname@example.com>
Date:   Mon Oct 30 12:00:00 2023 +0800

    完成登录功能开发
  • 这表示你已经成功将修改提交到了本地仓库。

五、回退到之前的版本

假设你在开发过程中发现代码出现了问题,想要回退到之前的版本。

  1. 查看提交历史:使用 git log 命令查看提交历史,找到你想要回退到的版本的 commit id。
git log
  • 你会看到类似以下的输出:
commit 1234567890abcdef1234567890abcdef12345678 (HEAD -> feature/login)
Author: yourname <yourname@example.com>
Date:   Mon Oct 30 12:00:00 2023 +0800

    完成登录功能开发

commit 0987654321fedcba0987654321fedcba09876543
Author: yourname <yourname@example.com>
Date:   Mon Oct 30 11:00:00 2023 +0800

    初始化项目
  • 假设你想要回退到 “初始化项目” 的版本,commit id 是 0987654321fedcba0987654321fedcba09876543
  1. 回退到指定版本:使用 git reset 命令回退到指定版本。
git reset --hard 0987654321fedcba0987654321fedcba09876543
  • 这会将工作区、暂存区和本地仓库都回退到指定版本。
  1. 查看工作区状态:使用 git status 命令查看工作区状态。
git status
  • 你会看到类似以下的输出:
On branch feature/login
nothing to commit, working tree clean
  • 这表示你已经成功回退到了指定版本。

https://github.com/0voice


http://www.niftyadmin.cn/n/5861467.html

相关文章

UE5.3 C++ TArray系列(一)

一.TArray概述 它们就相当于C动态数组Vector&#xff0c;但是被UE封装了&#xff0c;懂得都懂反射嘛&#xff0c;要不一不小心就被回收了。 它真的非常常见&#xff0c;我所用的容器中&#xff0c;它绝对排名第一&#xff0c;第二是TMap。 同类好理解&#xff0c;我平时也常用…

将Google文档导入WordPress:简单实用的几种方法

Google文档是内容创作者非常实用的写作工具。它支持在线编辑、多人协作&#xff0c;并能够自动保存内容。但当我们想把Google文档中的内容导入WordPress网站时&#xff0c;可能会遇到一些小麻烦&#xff0c;比如格式错乱、图片丢失等问题。本文将为大家介绍几种简单实用的方法&…

网络行为管理系统是什么?有什么功能?

​简单来说&#xff0c;网络行为管理系统就是对网络进行有效的规范约束和调整&#xff0c;关于网络行为管理系统的相关问题整理了一些详细介绍供大家参考。 一、什么是网络行为管理系统&#xff1f; 在数据网络和数据通信业务发展非常迅速&#xff0c;在数据网络和通信业务迅…

【C】识别一份嵌入式工程文件

是一个 STM32 嵌入式工程的目录。每个文件夹和文件都有其特定的功能和作用。以下是对各个文件夹和文件的解释&#xff1a; 1. .svn 文件夹 目的&#xff1a;这是 Subversion&#xff08;SVN&#xff09; 的版本控制文件夹。Subversion 是一种常用的版本控制工具&#xff0c;用…

如何解决服务器端口被攻击:全面防护与快速响应

服务器端口被攻击是网络安全中常见的问题之一&#xff0c;尤其是当服务器暴露在公共网络上时&#xff0c;容易成为黑客的目标。攻击者可能通过扫描开放端口、利用漏洞或发动拒绝服务&#xff08;DoS/DDoS&#xff09;攻击来破坏服务器的正常运行。本文将详细介绍如何检测、防御…

【系统架构】分布式事务模型详解

1. 分布式基础理论 1.1 CAP理论 CAP 理论可以表述为&#xff0c;一个分布式系统最多只能同时满足一致性&#xff08;Consistency&#xff09;、可用性&#xff08;Availability&#xff09;和分区容错性&#xff08;Partition Tolerance&#xff09;这三项中的两项。 一致性是…

【以无克有】排序之归并排序

分治的另一思路&#xff1a;千古兴亡多少事&#xff0c;悠悠。不尽长江滚滚流。 归并排序原理原理讲解代码实现合并(merge)部分递归树排序部分 复杂度简要分析例题归并排序模板归并排应用之逆序对 参考资料及推荐学习总结 归并排序原理 原理讲解 分治策二&#xff1a;拆解与合…

【Linux】【网络】frp 如何准确将 客户端B 请求转发给 服务器A 的

【Linux】【网络】frp 如何准确将 客户端B 请求转发给 服务器A 的 先来看一下上个文章的配置 1配置部分 1.1frp 配置 frp一直在监听7000这个端口上是否有请求到达 [common] bind_port 7000 # 云服务器监听的端口1.2 服务器A配置 [common] server_addr frp_ip; # 云服…