Git新手教程-查看仓库的历史记录(四)

title.jpg

前言

在前面的文章中,我们学习了如何创建仓库。现在我们将学习如何查看仓库的历史记录,之所以没有先讲解如何向仓库如何提交commit,是因为我觉得,只有先了解历史记录中包含哪些信息后,我们才能更好的创建良好的提交。有了良好的提交,才会有助于以后我们对项目的整体回顾。在本文章中,我们将介绍 git loggit show 两个指令,这里先简单介绍一下这两个命令的功能。

  • git log:查看现有的提交信息
  • git show:可以显示给定提交的信息。

git log 命令

当然使用 git log 命令,我们首先需要一个现有的Git仓库,这里还是以我自己的项目SimpleEyes项目为例。

还记得我们之前的介绍的 git clone 命令吗?我们先 clone 该项目吧.

git clone https://github.com/AndyJennifer/SimpleEyes

克隆该项目后,我们通过 cd 命令进入该项目,使用 git log 命令,我们能得到下列输出:

git_log展示界面.png

历史记录分析

默认情况下,使用 git log 命令会显示仓库中每个 commit 的详细提交信息。结合上图,我们来分析下每行所代表的具体内容。这里以第一个历史提交记录为例:

  • commit头信息
commit 543019ea4bca77c31ccd1d06c4ca2ca4b1d69b23 (HEAD -> master, origin/master, origin/HEAD)

在Git中会为每个提交生成一个ID,也就是SHA。在本行中不仅显示了提交的ID,当前所指向的分支为 master ,当然现在我们可能还不了解分支的相关信息,不过请大家放心,我们会在后续的文章中学到它的。

SHA是一个长 40 个字符的字符串(由 0–9 和 a–f 组成),并根据 Git 中的文件或目录结构的内容计算得出。SHA 的全称是"Secure Hash Algorithm"(安全哈希算法)。如果你想了解哈希算法,可以参考SHA家族

  • 作者
Author: AndyJennifer <1225868370@qq.com>

当前行显示了提交这个commit的作者以及对应邮件信息。现阶段这个仓库只有我一个人维护,所以这里全是我的相关信息。当然,如果你的仓库是多人协作开发,那么不同的作者提交的commit所对应的Author也会不同啦。

  • 日期
Date:   Thu Aug 29 23:43:07 2019 +0800

日期,很简单,就是现实当前 commit 的时间,一般情况下,我们是不会关心它的。

  • commit消息
 修改了切换视频时,controller没有设置,导致的空指针异常

一般情况下,我们需要为每次提交的内容进行说明,比如增加了什么功能,修改了什么bug等等。一个良好的commit 提交内容与提交消息之间应该有着一一对应的关系,而不是表述模糊,张冠李戴。

git log 命令行日志浏览快捷键

如果你是第一次使用git log命令,可能会有一个疑问,如何加载更多的历史记录呢?如何退出呢?如果大家仔细观察,在我们的界面中末尾有个冒号,该冒号表明还可以显示更多的输出行。在Git中是使用 Less 程序作为其分页器,如果你不熟悉 less 或分页器也没有问题。大家只要知道该分页器是用于翻页并浏览内容的就行了。下面我们看看该分页器对应的按键指令。

要向下滚动:

  • j 一次向下移动一行
  • d 按照一半的屏幕幅面移动
  • f 按照整个屏幕幅面移动

要向上滚动:

  • k 一次向上移动一行
  • u 按照一半的屏幕幅面移动
  • b 按照整个屏幕幅面移动

需要注意的是,当冒号变为单词END时,表示记录显示完毕,那么我们可以按下 q 可以离开分页器。

更改 git log 显示信息的方式

git log --oneline

使用 git log 命令,会显示日期、作者、commit消息等信息,但是有些情况下,我们可能并不关心日期、或相关作者。我们只想快速的浏览具体的提交信息,那么我们可以为当前的 git log 命令,增加一个选项 --oneline

注意这里是 oneline 而不是 online

使用 git log --oneline 我们能得到如下输出:

git-log--oneline展示.png

使用 git log --oneline 命令会:

  • 每行显示一个 commit
  • 显示 commit 的 SHA 的前 7 个字符
  • 显示 commit 的消息

查看修改后的文件

在了解了 git log --oneline 命令后,我们可能会想深入了解某个commit更改了哪个或哪些文件。这个时候我们需要 git log 的另一个选项 --stat

stat 是单词 statistics ,为统计的意思。

使用 git log --stat 命令,我们能得到如下输出:

这里为了方便讲解,我只截取了特征明显的commit

git-log--stat展示.png

上图中最后一行,表明这次提交共涉及到8个文件的修改,160行的插入,5行的删除。其中build.gradle文件中删除了1行,UserPreferences.kt中添加或删除了2行......相信到这里大家就明白了,使用命令git log --stat会:

  • 显示被修改的文件
  • 显示添加/删除的行数
  • 显示一个摘要,其中包含修改/删除的总文件数和总行数

查看文件更改

在上文中,我么已经通过添加 --stat 选项,可以知道修改了哪些文件,以及添加/删除了多少行代码。如果能查看文件中到底进行了哪些更改,是不是更好呢?在 git log 命令中具有一个可用来显示对文件作出实际更改的选项,就是 --patch ,可以简写为 -p

例如,我们想查看下图中具体的修改:

git-log-p1.png

我们使用 git log -p 命令,我们能够得到一下输出:

git-log-p2.jpg

在上述输出信息中,包含5个比较重要的信息:

  • 第一个:diff显示了原始版本与新版本间的差异,我们现在看到的IjkVideoView.java文件,其中a/app/../IjkVideoView.java为该文件的第一个版本,b/app/../IjkVideoView.java为新版本。
  • 第二个:显示了第一个版本文件的哈希值与文件更改后的哈希值,这些哈希值和提交的 SHA 是不同的。
  • 第三个:也是显示了不同版本的文件差异,其中 - 表示旧版本, + 表示新版本。
  • 第四个:添加的行所在的位置以及添加了多少行。
    • -333,8表示原始版本(用 - 表示),从338行开始,显示了8行。
    • +333,10表示新版本(用 + 表示),从338行开始,现在变成了10行,这10行在命令窗口中显示了。
  • 第五个:表示了在commit中实际进行的更改。
    • 用红色并以 减号(-)开头的行是位于文件原始版本中,但是被 commit 删除的行
    • 用绿色标示并以 加号(+)开头的行是 commit 新加的行

查看特定的commit

上文中涉及到的命令,是对全部的历史记录进行浏览,如果说能够单独的显示某个提交信息是不是很棒呢?在Git中有两种方式来查看特定的提交。

  • 使用 git log 提供你要查看的 commit 的 SHA
  • 使用 git show

这里我们先 git log 方式,然后再学习 git show。

使用 git log 方式

在上文中,我们已经学会如何使用以下命令输出信息:

  • git log
  • git log --oneline
  • git log --stat
  • git log -p

但是你是否知道,可以向所有这些命令提供 commit 的 SHA 作为最后一个参数?例如:

git log 543019ea

在Git中支持完整的 SHASHA前七个字符 作为具体的查询条件。

需要注意的是使用git log+ SHA 的这种方式,并不会单独的显示某个提交。而是命令行将从这条提交开始输出历史记录,你仍然可以通过Git提供的分页器,查看该条提交信息之后的记录。

使用 git show 方式

使用 git show + SHA 的方式,可以显示特定的提交信息。如

git show 543019ea

git show默认情况下会显示:

  • commit头信息
  • 作者
  • 日期
  • commit 消息
  • 具体的文件差异

这里就不再暂时示例图片了,希望大家多多练习,并查看最终效果吧。

IntelliJ IDEA or Android Sutdio 图形化界面的使用

最后还是回到我们熟悉的图形化界面的使用流程中。我们来看看IDEA为我们提供了哪些便利吧。

通过依次点击编译器底部的Version Control->Log,我们能得到如下界面:

studioLog界面显示.jpg

现在分别上图标注的内容进行介绍:

  1. 提交记录展示列表:在该区域显示了我们所有的提交内容,包含commit信息、作者、日期。
  2. 搜索框:我们能根据关键字搜索到我们想要查询的提交信息。
  3. User筛选框:我们可以筛选其他作者的提交信息
  4. Date筛选框:根据日期来查询提交信息。
  5. 通过点击相关提交记录,我们能查看对应提交对文件的操作(增加,删除,更改),如果点击相关文件,可以查看当前提交内容与上个版本的区别。
  6. 通过点击相关提交记录,我们能查看到详细的提交信息,包括SHA值,提交用户,邮件等其他信息。

最后

站在巨人的肩膀上,才能看的更远~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352