【Git】工作区、暂存区和版本库

server/2024/11/23 2:00:09/

目录

一、基本概念:

关系图:

 1. 工作区(Working Directory)

   $ 1.1 工作区功能

$ 1.2 工作区特点

2. 暂存区(Staging Area)

$ 2.1 暂存区功能

$ 2.2 暂存区特点

$ 2.3 常用命令

3. 版本库(Repository)

$ 3.1 版本库功能

$ 3.2 版本库特点

$ 3.3 常用命令

 二、工作区、暂存区和版本库之间的关系

1. 工作区 -> 暂存区

2. 暂存区 -> 版本库

 3. 版本库 -> 远程仓库

4. 远程仓库 -> 本地版本库

实例:


一、基本概念:

        工作区:就是电脑里能看到的目录。

        暂存区:英文叫stage或index。一般存放在 .git 目录下的index文件(.git/index)中,所以我们把暂存区有时也叫索引(index)。

        版本库:工作区有一个隐藏目录 .git  ,这个不算工作区,而是Git的版本库。

关系图:

 

  • 图中左侧为工作区,右侧为版本库。在版本库中标记为 "index" 的区域是暂存区(stage/index),标记为 "master" 的是 master 分支所代表的目录树。

  • 图中我们可以看出此时 "HEAD" 实际是指向 master 分支的一个"游标"。所以图示的命令中出现 HEAD 的地方可以用 master 来替换。

  • 图中的 objects 标识的区域为 Git 的对象库,实际位于 ".git/objects" 目录下,里面包含了创建的各种对象及内容。

  • 当对工作区修改(或新增)的文件 执行 git add 命令时,暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID被记录在暂存区的文件索引中。

  • 当执行提交操作(git commit)时,暂存区的目录树写到版本库(对象库)中,master 分支会做相应的更新。即 master 指向的目录树就是提交时暂存区的目录树

  • 当执行 git reset HEAD 命令时,暂存区的目录树会被重写,被 master 分支指向的目录树所替换,但是工作区不受影响。

  • 当执行 git rm --cached <file> 命令时,会直接从暂存区删除文件,工作区则不做出改变。

  • 当执行 git checkout . 或者 git checkout -- <file> 命令时,会用暂存区全部或指定的文件替换工作区的文件。这个操作很危险,会清除工作区中未添加到暂存区中的改动。

  • 当执行 git checkout HEAD . 或者 git checkout HEAD <file> 命令时,会用 HEAD 指向的 master 分支中的全部或者部分文件替换暂存区和以及工作区中的文件。这个命令也是极具危险性的,因为不但会清除工作区中未提交的改动,也会清除暂存区中未提交的改动。

 1. 工作区(Working Directory)

   $ 1.1 工作区功能

        工作区是本地计算机上的项目目录,在这里进行文件的创建、修改和删除操作。

        工作区包含了当前项目的所有文件和子目录。

$ 1.2 工作区特点

  •         显示项目的当前状态。
  •         文件的修改在工作区中进行,但这些修改还没有被记录到版本控制中。

2. 暂存区(Staging Area)

$ 2.1 暂存区功能

        暂存区是一个临时存储区域,它包含了即将被提交到版本库中的文件快照,在提交之前,可以选择性地将工作区中的修改添加到暂存区。

$ 2.2 暂存区特点

  •         暂存区保存了将被包含在下一个提交中的更改。
  •         可以多次使用git add命令来将文件添加到暂存区,直到准备好提交所有更改。

$ 2.3 常用命令

git add filename       # 将单个文件添加到暂存区
git add .              # 将工作区中的所有修改添加到暂存区
git status             # 查看哪些文件在暂存区中

3. 版本库(Repository)

$ 3.1 版本库功能

        版本库包含了项目的所有版本历史记录。

        每次提交都会在版本库中创建一个新的快照,这些快照是不可变的,确保了项目的完整历史记录。

$ 3.2 版本库特点

  •         版本库分为本地版本库和远程版本库。(这里主要指本地版本库)
  •         本地版本库存储在 .git 目录中,他包含了所有提交的对象和引用。

$ 3.3 常用命令

git commit -m "Commit message"   # 将暂存区的更改提交到本地版本库
git log                          # 查看提交历史
git diff                         # 查看工作区和暂存区之间的差异
git diff --cached                # 查看暂存区和最后一次提交之间的差异

 二、工作区、暂存区和版本库之间的关系

1. 工作区 -> 暂存区

使用 git add 命令将工作区中的修改添加到暂存区。

git add filename

        " . "是所有

git add .

2. 暂存区 -> 版本库

使用git commit 命令将暂存区中的修改提交到版本库。

git commit -m "Commit message"

        引号里填提交信息。

 3. 版本库 -> 远程仓库

使用 git push 命令将本地版本库的提交推送到远程仓库。

git push origin +分支名。

git push origin branch-name

4. 远程仓库 -> 本地版本库

使用 git pull或 git fetch 命令从远程仓库获取更新。

git pull origin branch-name
# 或者
git fetch origin branch-name
git merge origin/branch-name

实例:

1. 从远程仓库中(master分支)得到文件到本地电脑。

git clone

2. 在工作区(目录)中修改文件后添加到暂存区。

git add .

3. 将暂存区的修改提交到本地版本库。

git commit -m"第一次提交"

4. 将本地提交推送到远程仓库。

git push

若有分支,clone后就进入,提交等操作都在分支中进行。

git push origin Hou

"Hou"为我的分支名。


http://www.ppmy.cn/server/144149.html

相关文章

国产系统(麒麟V10、uos)使用pageoffice在线编辑office文件

本文描述了PageOffice产品在&#xff08;VUESpringboot&#xff09;前后端分离的项目中如何集成调用。 一、环境 前端&#xff1a;vue2 后端&#xff1a;springboot2、jdk1.8 如果是springboot3&#xff0c;jdk17及以上版本&#xff0c;用这个依赖&#xff1a; <dependen…

网络安全中常用浏览器插件、拓展

引言 现在的火狐、Edge&#xff08; Chromium内核&#xff09;、Chrome等浏览器带有插件、拓展&#xff08;Plugin&#xff09;的功能。这些插件中有的可以过滤广告&#xff0c;有的提供便捷的翻译&#xff0c;有的提供JavaScript脚本支持&#xff0c;方便用户的使用也大大的增…

蓝桥杯每日真题 - 第16天

题目&#xff1a;&#xff08;卡牌&#xff09; 题目描述&#xff08;13届 C&C B组C题&#xff09; 解题思路&#xff1a; 题目分析&#xff1a; 有 n 种卡牌&#xff0c;每种卡牌的现有数量为 a[i]&#xff0c;所需的最大数量为 b[i]&#xff0c;还有 m 张空白卡牌。 每…

WebSocket详解、WebSocket入门案例

目录 1.1 WebSocket介绍 http协议&#xff1a; webSocket协议&#xff1a; 1.2WebSocket协议&#xff1a; 1.3客户端&#xff08;浏览器&#xff09;实现 1.3.2 WebSocket对象的相关事宜&#xff1a; 1.3.3 WebSOcket方法 1.4 服务端实现 服务端如何接收客户端发送的请…

【NodeJS】Node.js是什么?能做什么?

👉博主介绍: 博主从事应用安全和大数据领域,有8年研发经验,5年面试官经验,Java技术专家,WEB架构师,阿里云专家博主,华为云云享专家,51CTO 专家博主 ⛪️ 个人社区:个人社区 💞 个人主页:个人主页 🙉 专栏地址: ✅ Java 中级 🙉八股文专题:剑指大厂,手撕 J…

springboot基于SpringBoot的校园招聘网站的设计与实现现

摘 要 校园招聘网站是一个专门为高校毕业生和用人单位提供就业与招聘信息的网络平台。该网站通过现代互联网技术&#xff0c;实现了职位信息的发布、简历投递、在线沟通等功能&#xff0c;极大地方便了企业和学生之间的互动。在设计上&#xff0c;网站注重用户体验&#xff0c…

unity li2cpp逆向原理是什么?

主要涉及将Unity游戏引擎中的C#代码转换为C代码&#xff0c;并进一步编译为各平台的原生&#xff08;Native&#xff09;代码的过程&#xff0c;以及逆向工程工具如何利用这一过程中的特定文件来还原和分析原始代码。以下是对Unity IL2CPP逆向原理的详细解释&#xff1a; 对惹…

Python小游戏28——水果忍者

首先&#xff0c;你需要安装Pygame库。如果你还没有安装&#xff0c;可以使用以下命令进行安装&#xff1a; 【bash】 pip install pygame 《水果忍者》游戏代码&#xff1a; 【python】 import pygame import random import sys # 初始化Pygame pygame.init() # 设置屏幕尺寸 …