HoRain云--Git 工作区、暂存区和版本库
HoRain 云小助手个人主页⛺️生活的理想就是为了理想的生活!⛳️ 推荐前些天发现了一个超棒的服务器购买网站性价比超高大内存超划算忍不住分享一下给大家。点击跳转到网站。目录⛳️ 推荐基本概念1、工作区Working Directory2、暂存区Staging Area3、版本库Repository工作区、暂存区和版本库之间的关系实例基本概念我们先来理解下 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 filename2、暂存区 - 版本库使用 git commit 命令将暂存区中的修改提交到版本库。git commit -m Commit message3、版本库 - 远程仓库使用 git push 命令将本地版本库的提交推送到远程仓库。git push origin branch-name4、远程仓库 - 本地版本库使用 git pull 或 git fetch 命令从远程仓库获取更新。git pull origin branch-name # 或者 git fetch origin branch-name git merge origin/branch-name实例假设你在工作目录中修改了 file.txt1、工作区修改 file.txt 并保存。2、暂存区将修改添加到暂存区git add file.txt3、版本库将暂存区的修改提交到本地版本库git commit -m Update file.txt4、远程仓库将本地提交推送到远程仓库git push origin main通过理解工作区、暂存区和版本库的作用及其相互关系你可以更加高效地使用 Git 进行版本控制和协同开发。❤️❤️❤️本人水平有限如有纰漏欢迎各位大佬评论批评指正如果觉得这篇文对你有帮助的话也请给个点赞、收藏下吧非常感谢! Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧