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

🚀 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实战:

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

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

  • 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.htmlmodified:   style.cssmodified:   script.jsno 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.htmlmodified:   style.cssmodified:   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.rhkb.cn/news/19766.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

胶囊网络动态路由算法:突破CNN空间局限性的数学原理与工程实践

一、CNN的空间局限性痛点解析 传统CNN的瓶颈&#xff1a; 池化操作导致空间信息丢失&#xff08;最大池化丢弃85%激活值&#xff09;无法建模层次空间关系&#xff08;旋转/平移等变换不敏感&#xff09;局部感受野限制全局特征整合 示例对比&#xff1a; # CNN最大池化示例…

如何下载AndroidStudio的依赖的 jar,arr文件到本地

一、通过jitpack.io 下载依赖库 若需要下载 com.github.xxxxx:yy-zzz:0.0.2 的 jar则 https://jitpack.io/com/github/xxxxx/yy-zzz/0.0.2/ 下会列出如下build.logyy-zzz-0.0.2.jaryy-zzz-0.0.2.pomyy-zzz-0.0.2.pom.md5yy-zzz-0.0.2.pom.sha1jar 的下载路径为https://jitpack…

Ubuntu中离线安装Docker

Ubuntu中离线安装Docker 前言 本教程将详细介绍如何在 Ubuntu 22.04 系统上&#xff0c;通过 .deb 包离线安装 Docker CE、Docker CE CLI 和 Docker Compose。 适用于无法访问互联网的环境。 准备工作 下载 .deb 包 在可以访问互联网的机器上&#xff0c;下载 Docker CE、…

【科研创新与智能化转型】AI智能体开发与大语言模型的本地化部署、优化技术

智能体&#xff08;Agent&#xff09;是指能够感知环境、自主决策并采取行动以实现特定目标的实体。它可以是一个软件程序、机器人或任何具备自主行为的系统。智能体的核心特征包括自主性、反应性、目标导向性和社会性。 智能体的主要特征 自主性&#xff1a;能够在没有外部干预…

【拒绝算法PUA】LeetCode 1287. 有序数组中出现次数超过25%的元素

系列文章目录 【拒绝算法PUA】0x00-位运算 【拒绝算法PUA】0x01- 区间比较技巧 【拒绝算法PUA】0x02- 区间合并技巧 【拒绝算法PUA】0x03 - LeetCode 排序类型刷题 【拒绝算法PUA】LeetCode每日一题系列刷题汇总-2025年持续刷新中 C刷题技巧总结&#xff1a; [温习C/C]0x04 刷…

6.2.4 基本的数据模型

文章目录 基本的数据模型 基本的数据模型 基本的数据模型包含层次模型&#xff0c;网状模型和关系模型。 层次模型&#xff1a;使用树型结构表示数据间联系。记录间的联系用指针实现&#xff0c;简单高效。但是只能表示1:n的联系&#xff0c;且对插入、删除的限制多。网状模型…

前端JS接口加密攻防实操

前端JS接口加密攻防实操 背景 在爬虫过程中&#xff0c;对数据接口各类加密的经历总结&#xff0c;无头消耗资源效率不高&#xff0c;采用浏览器兜底解密协程并行 青铜版(混淆对称加密|签名nonce等&#xff09; 解&#xff1a;根据API 调用栈&#xff0c;断点找到request参…

嵌入式AI(2)清华大学DeepSeek 01:从入门到精通

嵌入式AI(2)清华大学DeepSeek 01&#xff1a;从入门到精通

SpringBoot+Vue+数据可视化的动漫妆造服务平台(程序+论文+讲解+安装+调试+售后等)

感兴趣的可以先收藏起来&#xff0c;还有大家在毕设选题&#xff0c;项目以及论文编写等相关问题都可以给我留言咨询&#xff0c;我会一一回复&#xff0c;希望帮助更多的人。 系统介绍 在当今数字化高速发展的时代&#xff0c;动漫产业迎来了前所未有的繁荣&#xff0c;动漫…

Ubuntu 22.04.5 LTS 安装企业微信,(2025-02-17安装可行)

一、依赖包(Ubuntu 20.04/Debian 11) 点击下载https://www.spark-app.store/download_dependencies_latest 1、 下载最新的依赖包。 请访问星火应用商店依赖包下载页面, 下载最新的依赖包。2、解压依赖包 </

假面与演员:到底是接口在使用类,还是类在使用接口?编程接口与物理接口的区别又是什么?

前言&#xff1a;本篇文章解释了接口学习过程中的2个常见问题&#xff0c;一个是“为什么是类在使用接口”&#xff0c;另一个一个是“编程接口与物理接口的差异源于所处的抽象层次和交互模式的不同”&#xff0c;旨在揭示编程接口的本质。 Part1.是类在使用接口 当学习接口时…

python opencv基础使用总结

1.安装opencv库&#xff1a;pip install opencv-python 2.基础使用范例 import cv2 #图片的基本操作#1.读取一张图片 参数 1&#xff1a;图片的文件名如果图片放在当前文件夹下&#xff0c;直接写文件名就行&#xff0c;如lena.jpg否则需要给出绝对路径&#xff0c;如D:\Ope…

C++17 数学特殊函数:探索标准库中的强大工具

文章目录 1. 什么是数学特殊函数&#xff1f;2. C17 中的特殊函数2.1 贝塞尔函数2.2 勒让德函数2.3 椭圆积分2.4 伽马函数2.5 误差函数 3. 实际应用场景3.1 科学计算3.2 工程应用3.3 数据分析 4. 总结 在 C17 中&#xff0c;标准库引入了一系列数学特殊函数&#xff0c;这些函数…

mysql多主集群 galera cluster for mysql 8安装配置启动重启集群

[TOC] 一、安装mysql 1、安装 系统环境&#xff1a; Ubuntu 18.04 64位 MySQL 8.0.19 下载MySQL APT安装配置包 首先访问 https://dev.mysql.com/downloads/repo/apt/ 获取配置包下载地址 wget https://dev.mysql.com/get/mysql-apt-config_0.8.14-1_all.deb sudo dpkg -i mysq…

面向长范围交互式 LLM 智体的强化学习

25年2月来自 Apple 的论文“Reinforcement Learning for Long-Horizon Interactive LLM Agents”。 交互式数字智体 (IDA) 利用状态数字环境的 API 来执行任务以响应用户请求。虽然由指令调整的大语言模型 (LLM) 驱动 IDA 可以对多步交换中接口调用的反馈做出反应&#xff0c;…

sql语言语法的学习

sql通用语法 sql分类 DDL(操作数据库和表) 操作数据库 操作表_查询 操作表_创建 举例&#xff1a; 操作表_删除 操作表_修改 DML(增删改表中数据) DML添加数据 DML删除数据 DML修改数据 DQL 单表查询 基础查询 条件查询 案例演示&#xff1a; 排序查询 聚合函数 分组查询…

kkFileView二开之pdf转图片接口

kkFileView二开之Pdf转图片接口 kkFileView二开系列文章&#xff1a;1 kkFileView源码下载及编译2 Pdf转图片接口2.1 背景2.2 分析2.2 接口开发2.2.1 编写Pdf转图片方法2.2.2 编写转换接口 2.3 接口测试2.3.1 Pdf文件准备2.3.2 pdf2Image 3 部署 kkFileView二开系列文章&#x…

Electron 客户端心跳定时任务调度库调研文档 - Node.js 任务调度库技术调研文档

Electron 客户端心跳定时任务调度库调研文档 - Node.js 任务调度库技术调研文档 本文将对七个流行的定时任务调度库&#xff1a;node-cron、rxjs、bull、node-schedule、agenda、bree、cron。这些库都可以用来处理定时任务&#xff0c;但它们的特点和适用场景有所不同。我们将从…

驱动开发系列37 - Linux Graphics 2D 绘制流程(二)- 画布创建和窗口关联

一:概述 前面介绍Pixmap表示一块画布,是绘制发生的地方,本节看看驱动程序如何为画布分配内存/显存,以及如何与窗口关联的。 二:为画布分配BO 在系统启动时(用户登录系统之后,会重启Xorg),在 Xorg 服务器初始化时,要为屏幕创建根窗口的 Pixmap,并绑定到 GPU framebu…

Numpy简易入门

1.1 认识Numpy数组对象 1.1.1 导入NumPy工具包 #导包并起别名为np import numpy as np1.1.2 创建一个三行五列的数组 data np.arange(15).reshap(3, 5)打印结果&#xff1a; 1.1.3 查询data类型 print(type(data))打印结果&#xff1a; <class numpy.ndarray> nda…