Git实用教程5:状态(查询状态、查看历史提交)

本节主要知识点:


查询状态

在命令行中将路径切换至文件夹中,然后使用命令git status

查看历史提交

在命令行中将路径切换至文件夹中,然后使用命令git log

自动将所有“已跟踪”的文件先 add 到暂存区域,然后再执行 commit 命令

在命令行中将路径切换至文件夹中,然后使用命令git commit -am "change the license file"




一个项目百八十个文件,怎么知道哪些文件是新添加的,哪些文件已经加入了暂存区域呢?

状态


可以使用 git status 命令查看当前的状态……

上一讲的代码如果你没有动过,那么输入 git status 命令后应该是下边这样:

在这里插入图片描述
On branch master 说明我们位于一个叫做“master”的分支里,这是默认的分支(相比其他版本管理程序,Git 的分支理念领先世界好几年 放心,在适当的时候小甲鱼会详细地给大家讲解分支的)。

nothing to commit, working directory clean 说明你的工作目录目前是“干净的”,没有需要提交的文件(意思就是自上次提交后,工作目录中的内容压根儿就没改动过)。

既然要做大项目,那么应该增加一个版权声明。为了显得大公无私,我们采用 MIT 许可证给予用户最大的权利,让全世界的开发者都参与进来!

在工作目录中增加 LICENSE 文件,内容如下:

Copyright ©

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

MIT 许可证几乎是最宽松的版权约定,一旦你的程序采用,也就意味着别人只要在软件包含上边的版权声明,就可以对你的程序为所欲为了(包括“使用、复制、修改、合并、出版发行、散布、再授权和/或贩售软件及软件的副本”)。

现在我们输入 git status 命令,看下 git 有什么想法:
Git实用教程5:状态(查询状态、查看历史提交)_第1张图片
Untracked files 说明存在未跟踪的文件(下边红色的那个)

所谓的“未跟踪”文件,是指那些新添加的并且未被加入到暂存区域或提交的文件。它们处于一个逍遥法外的状态,但你一旦将它们加入暂存区域或提交到 Git 仓库,它们就开始受到 Git 的“跟踪”。

这里圆括号中的英文是 git 给我们的建议:使用 git add 命令将待提交的文件添加到暂存区域。

所以只需要将这个文件 add 到 git 中就可以了
在这里插入图片描述
再来看一下 git 的当前状态:
Git实用教程5:状态(查询状态、查看历史提交)_第2张图片
use "git reset HEAD ..." to unstage 的意思是“如果你反悔了,你可以使用 git reset HEAD 命令恢复暂存区域”。

如果你输入了这串命令那么又会回到原来的起点:
Git实用教程5:状态(查询状态、查看历史提交)_第3张图片
这时 再次添加到暂存区域,然后执行 git commit -m "add a license file" 命令即可。

突然发现版权那块忘了写上咱自家的名字了……

打开 LICENSE 文件,将 Copyright © 改为 Copyright © 2019 + 自己的名字 ,保存……

执行 git status 命令:
Git实用教程5:状态(查询状态、查看历史提交)_第4张图片
由于你对工作目录的文件进行了修改,导致这个文件和暂存区域的对应文件不匹配了,所以 Git 又给你提出两条建议:

  • 使用 git add 命令将工作目录的新版本覆盖暂存区域的旧版本,然后准备提交
  • 使用 git checkout 命令将暂存区域的旧版本覆盖工作目录的新版本(危险操作:相当于丢弃工作目录的修改)

还有一种情况我们没分析,大家先把新版本的文件覆盖掉暂存区域的旧版本:
Git实用教程5:状态(查询状态、查看历史提交)_第5张图片
然后我们打开 LICENSE 文件,将 FishC 改为 FishC.com,保存……

再次查看状态:
Git实用教程5:状态(查询状态、查看历史提交)_第6张图片
这次诡异了:被绿的 LICENSE 说明文件存放在暂存区域(待提交),同时红色的 LICENSE 说明文件还在工作目录等待添加到暂存区域。

这种情况你应该意识到这里存在两个不同版本的 LICENSE 文件,这时如果你直接执行 commit 命令,那么提交的是暂存区域的版本(FishC),如果你希望提交工作目录的新版本(FishC.com),那么你需要先执行 add 命令覆盖暂存区域,然后再提交……

老是要 add 再 commit,很烦恼吧?

有没有办法一步到位?

答案当然是 Yes!

教你一步到位的技巧:在 commit 的时候,加上 -a 选项即可。

执行 git commit -am "change the license file" 命令:
Git实用教程5:状态(查询状态、查看历史提交)_第7张图片
解释:
-a 选项其实是专为懒人添加的。添加了 -a 选项,Git 会自动帮你将工作目录中所有“已跟踪”的文件先 add 到暂存区域,然后再执行 commit 命令。另外,-am 是 -a -m 的缩写.

你可能感兴趣的:(Git实用教程,Git及GitHub实用教程)