首页 > 其他分享 >Git 工作区、暂存区和版本库

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

时间:2024-09-23 11:49:04浏览次数:8  
标签:git 版本 暂存区 工作 Git 提交 目录

基本概念

我们先来理解下 Git 工作区、暂存区和版本库概念:

  • 工作区:就是你在电脑里能看到的目录。
  • 暂存区:英文叫 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)

工作区是你在本地计算机上的项目目录,你在这里进行文件的创建、修改和删除操作。工作区包含了当前项目的所有文件和子目录。

特点:

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

2、暂存区(Staging Area)

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

特点:

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

常用命令:

git add filename       # 将单个文件添加到暂存区

git add .              # 将工作区中的所有修改添加到暂存区

git status             # 查看哪些文件在暂存区中

3、版本库(Repository)

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

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

特点:

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

常用命令:

git commit -m "Commit message"   # 将暂存区的更改提交到本地版本库

git log                          # 查看提交历史

git diff                         # 查看工作区和暂存区之间的差异

git diff --cached                # 查看暂存区和最后一次提交之间的差异

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

1、工作区 -> 暂存区

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

git add filename

2、暂存区 -> 版本库

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

git commit -m "Commit message"

3、版本库 -> 远程仓库

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

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

实例

假设你在工作目录中修改了 file.txt:

1、工作区

修改 file.txt 并保存。

2、暂存区

将修改添加到暂存区:

git add file.txt

3、版本库

将暂存区的修改提交到本地版本库:

git commit -m "Update file.txt"

4、远程仓库

将本地提交推送到远程仓库:

git push origin main

通过理解工作区、暂存区和版本库的作用及其相互关系,你可以更加高效地使用 Git 进行版本控制和协同开发

标签:git,版本,暂存区,工作,Git,提交,目录
From: https://blog.csdn.net/2401_86544677/article/details/142453815

相关文章

  • Git回退远程的代码
    Git撤销pull命令1、运行gitreflog命令查看你的历史变更记录2.然后用gitreset--hardHEAD@{n},(n是你要回退到的引用位置)回退。比如上图可运行gitreset--hard40a9a83Git回退远程的代码先将本地的代码回退到你需要回退的位置(IDEA界面上操作就可以了)执行gitpush-f......
  • 从零开始一个git操作实例,图文并茂
    徒弟不懂git怎么用,于是写了篇文章,把本地git操作从头写了一遍,自己去看吧!0、基本概念•Git是一个免费、开源的、分布式版本控制系统•它使用一个特殊的叫做仓库的数据库来记录文件的变化•仓库中的每个文件都有一个完整的版本历史记录1)安装sudoapt-updatesudoapt-geti......
  • GitHub连接方式
    在国内使用GitHub时,选择使用HTTPS还是SSH取决于你的具体需求和使用场景。一、HTTPS的特点和适用情况1.易于设置:一般来说,HTTPS的设置相对简单。对于新手用户,它不需要额外生成SSH密钥对并进行配置,只需要提供用户名和密码(或使用个人访问令牌)即可进行操作。2.适用......
  • 如何下载旧版本app或者旧版本的电脑软件?下载旧版本手机app和电脑软件的方法
    下载旧版本软件的方法介绍,下面以下载旧版本剪映为例:......
  • Kubernetes最新版本部署完整过程(1.31)
    参考官方文档进行部署:Kubernetes一、环境准备本次实验使用的操作系统为:Centosstream91.1节点规划一台兼容的Linux主机。Kubernetes项目为基于Debian和RedHat的Linux发行版以及一些不提供包管理器的发行版提供通用的指令。每台机器2GB或更多的RAM(......
  • 从代码到部署:GitHub Actions实现Java项目CI/CD的完整实践
    从代码到部署:GitHubActions实现Java项目CI/CD的完整实践在现代软件开发中,持续集成和持续部署(CI/CD)已经成为了团队高效交付代码的关键策略。通过GitHubActions,可以轻松配置CI/CD流水线,实现从代码提交到部署的自动化工作流。本文将基于英语听力网站(studytool.site)项目介......
  • 长安启源A07全新真香版即将预售:性能升级增程、纯电双动力版本
    9月22日讯,长安汽车旗下启源品牌再度发力,宣布其热门车型A07全新真香版将于9月26日启动先享预订程序。据悉,这款新车可视作原有A07车型的升级款,重点在配置和技术细节上进行了多项改进,力求带给消费者更为优质、智能的驾乘体验。动力系统全面革新,兼顾性能与节能长安启源A07全新真......
  • 使用 GitHub Actions & Pages 托管 Honkit 发布的网站
    使用GitHubActions&Pages托管Honkit发布的网站Created:2024-09-22T13:48+08:00Published:2024-09-22T14:28+08:00Category:DevOps作为张雨生的骨灰级粉丝,我一直想把雨生的资料尽可能地收集起来,用网站或者电子书的形式发布。一番查找后,我选择了honkit制作电子书和......
  • git error: Your local changes to the following files would be overwritten by mer
    3ad1444d^..73e10933为远程分支新提交,ac-dev分支落后远程分支4bd1444d^..83e10922个提交。现对ac-dev分支进行了修改,打算将ac-dev分支同步到4bd1444d最新提交,并保留ac-dev分支落后时的修改;ac-dev落后修改后没有提交或将其隐藏,直接cherry-pick遇到以下错误。gitcherry-p......
  • git上传github
    git上传github创建仓库文件夹(任意位置),打开gitBashHere初始化git输入gitinit生成该文件夹输入上传的信息gitconfig--globaluser.name"用户名"gitconfig--globaluser.email"邮箱"复制需要上传的文件输入gitadd.输入检查状态gitstatus输......