git学习(三):git暂存区

时间:2021-02-16 09:01:54

回顾之前学过的命令:

 git init              // 初始化一个项目
git add // 将文件交给工作区
git commit // 提交修改

查看提交日志:

 git log               // 查看提交日志
git log --stat // 每次提交文件的变更统计

可进行空的提交,也就是不提交任何文件的修改:

 git commit --allow-empty

比较差异:

 git diff              // 查看修改后的文件于版本库中文件的差异

修改不能直接提交么?

对于已经commit到版本库中的文件,如果再修改的话,不能直接提交,还是要用git add命令添加一下才能提交。

可以从一下几个命令验证修改后直接提交并没有成功:

 git diff                     // 比较差异
git log --pretty=oneline // 查看提交日志
git status -s // 显示文件的状态, M表示修改了,??表示新增
 On branch master
Changes not staged for commit:
modified: welcome.txt Untracked files:
test.ini no changes added to commit

需要针对修改的文件使用git add命令,将修改的文件添加到"提交任务"中,然后才能提交!

对于其他的版本控制系统来说执行add操作是向版本库中添加新文件用的,修改的文件(已被版本控制跟踪的文件)在下次提交时会直接被提交。但是git为啥还要我们做一次add动作呢?

 git add welcome.txt     // 添加文件
git diff // 与中间状态以无区别
git diff HEAD // HEAD表示版本库的头指针
git status
git status -s // 输出的M的位置有变化

M位置不同的含义是什么呢?

在执行完git add命令之前,这个M位于第二列(第一列是一个空格),在执行完git add之后,字符M位于第一列,第二列是空白。

位于第一列的字符M:版本库中的文件与处于中间状态——提交任务(提交暂存区,stage)中的文件相比有改动

位于第二列的字符M:工作区当前的文件与处于中间状态——提交任务(提交暂存区,stage中的文件相比有改动。

先不忙着执行git commit命令,再执行一些操作

 echo "Bye-Bye." >> welcome.txt
git status
git status -s

git学习(三):git暂存区

git学习(三):git暂存区