git所划分成几个区域,各区域的作用

Git的区域分为 工作区、暂存区、本地仓库区

 

工作区(work directory):一般就是我们项目的根目录。

本地仓库(repository):我们在为项目添加本地库之后,会在工作区生成一个如下图所示的隐藏目录“.git”,.git目录即为当前工作区的本地版本库

暂存区(stage):版本库中设立一个暂存区(Stage or Index),作为用来直接跟工作区的文件进行交互,工作区文件的提交或者回滚首选都是通过暂存区,而版本库中除了暂存区之外,文件的提交的最终存储位置是分支(Branch),在创建版本库的时候默认都会有一个主分支(Master)。

 

  • git add files:把当前工作文件拷贝到暂存区域。
  • git commit:在暂存区域生成文件快照并提交到本地仓库。
  • git reset – files:用来撤销最后一次 git add files;
  • git reset 撤销所有暂存区域文件;
  • git checkout – files:把文件从暂存区域覆盖到工作目录,用来丢弃本地修改。

其中,reset操作是将暂存区内选中的目标文件从暂存区中丢弃,不影响其他任何区域的文件,等同于一个自刷新的动作;

 

 

相关命令

  • git commit -a 等同于连续执行 git add 与 git commit,即先把文件从工作目录复制到暂存区,然后再从暂存区复制到仓库中;
  • git checkout HEAD – files 的过程刚好相反,将工作区和暂存区都同步至当前分支内的状态;也就是最后一次commit的状态;
  • 撤销操作主要有如下几种
  • git commit   --amend        撤销上一次提交  并讲暂存区文件重新提交
  • git checkout -- <file>     拉取暂存区文件 并将其替换成工作区文件
  • git reset HEAD  -- <file>  拉取最近一次提交到版本库的文件到暂存区  改操作不影响工作区

 

相关命令

  • git diff:查看尚未暂存的文件更新了哪些部分;即当前状态下工作区和暂存区之间的差异。
  • git diff –cached:查看已暂存文件和上次提交时的快照之间的差异;即当前状态下暂存区和分支内的差异。
  • git diff HEAD:查看未暂存文件与最新提交文件快照的区别;即当前状态下工作区和分支内的差异。

 

注意:此图解主要针对已跟踪状态文件而言,对于新增文件,有些操作会有问题。

1. 修改本地已被跟踪文件,文件进入未暂存区域。

2. 未暂存区域转到暂存区域

  • git add files

3. 暂存区提交到本地仓库

  • git commit -m

4. 直接从未暂存区提交到本地仓库

  • git commit -am
  • 经测试,对已跟踪的文件可以正确执行,而对于未跟踪文件(即新增文件)则会出错

5. 本地库回退到暂存区

  • git reset –soft hash
  • git reset –soft origin/master
  • 一般回退到暂存区的文件作排查用,不要直接修改,不然会同时出现在暂存区和未暂存区(其实即使修改了也木有太大关系)

6. 本地库回退到未暂存区

  • git reset –mixed hash
  • git reset –mixed origin/master
  • 一般回退到未暂存状态就是为了进一步的修改

7. 本地库回退到文件初始状态(即此版本的)

  • git reset –hard hash
  • 注意这里,通常先执行一次fetch,保证本地版本是origin的最新版本,然后再回退。(最厉害的是,这么操作不会有冲突,直接让文件变成和origin保持一致)
    • git fetch origin
    • git reset –hard origin/master
    • 特别注意:这么操作会使你对文件的修改全部消失,还原成最初状态。
  • (针对上一条情况衍生讲解)通常在推送到origin时,先要pull,然后再推送,一般是修改提交了的文件和pull下来的同一个文件产生冲突(所以建议修改代码前,一定先要pull)
    • git pull
    • git push origin master

8. 暂存区回退到未暂存区

  • git reset – files
  • git rest
    • 撤销所有暂存区的文件

9. 未暂存区回退到文件初始状态

  • git checkout – files

10. 暂存区回退到文件初始状态

  • git checkout head – files
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Git中,主要有三个区域: 1. **工作(Working Directory)**[^1]:这是你在本地计算机上实际查看和编辑文件的地方。当你从仓库克隆项目或切换分支后,工作的内容会更新为你选择的分支状态。 2. **暂存区(Staging Area/Index)**:也称为索引,位于 `.git/index` 文件中。当你运行 `git add <file>` 命令时,你所做的更改会被添加到暂存区,准备被提交到版本控制。只有暂存区中的修改才会被包括在下一次的 `git commit` 中。 3. **本地仓库(Local Repository)**:存储着项目的完整历史记录,包括提交信息、分支等。你可以通过 `git clone` 克隆一个远程仓库来创建本地仓库,然后使用 `git commit` 和 `git push` 进行版本管理。 **示例操作流程:** 1. 修改工作文件 `test_1.txt`。 2. 使用 `git add test_1.txt` 将修改添加到暂存区。 3. 如果还想添加其他文件,可以使用 `git add ./*` 来一次性添加当前目录下的所有改动。 4. 对不需要的改动执行 `git rm test_2.txt`(如果它还未被暂存),并可能需要加上 `-r` 参数来递归删除文件及其子目录。 5. 当对暂存区的更改满意后,使用 `git commit -m "提交的log"` 创建一个新的提交,并记录一条描述性消息。 6. 最后,使用 `git push origin master` 将本地的提交推送到远程的master分支。 注意:`git checkout HEAD .` 或 `git checkout HEAD <file>` 可能会清空工作暂存区,因此在执行这些命令之前务必确认它们不会意外覆盖你尚未提交的改动。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值