git reflog 和 git log 的区别
发布日期:2021-06-30 12:24:24 浏览次数:2 分类:技术文章

本文共 1359 字,大约阅读时间需要 4 分钟。

  • git reflog

    可以查看所有分支的所有操作记录(包括已经被删除的 commit 记录和 reset 的操作),

  • git log

    则不能察看已经删除了的commit记录

具体一个例子,假设有三个commit:

git st:commit3: add test3.ccommit2: add test2.ccommit1: add test1.c

如果执行 git reset --hard HEAD~1 则删除了 commit3,如果发现删除错误了,需要恢复 commit3 就要使用

git reflog HEAD@{
0}: HEAD~1: updating HEAD63ee781 HEAD@{
1}: commit: test3:q

63ee781 即是被删除了的 commit3,运行 git log 则没有这一行记录

可以使用 git reset --hard 63ee781 将红色记录删除,则恢复了cmmit3,运行git log后可以看到:

commit3: add test3.ccommit2: add test2.ccommit1: add test1.c

这里也可以使用另外一种方法来实现:git cherry-pick 63ee781

Git log 常用选项

选项 说明

-p 按补丁格式显示每个更新之间的差异
–stat 显示每次更新的文件修改统计信息
–shortstat 只显示 –stat 中最后的行数修改添加移除统计
–name-only 仅在提交信息后显示已修改的文件清单
–name-status 显示新增、修改、删除的文件清单
–abbrev-commit 仅显示 SHA-1 的前几个字符,而非所有的 40 个字符
–relative-date 使用较短的相对时间显示(比如,“2 weeks ago”)
–graph 显示 ASCII 图形表示的分支合并历史
–pretty 使用其他格式显示历史提交信息。可用的选项包括 oneline,short,full,fuller 和 format(后跟指定格式)
限制输出长度
除了用 -n 来限制输出 log 的条数,还可以用 --since 和 --until 按照时间作限制。
用 --author 选项显示指定作者的提交,用 --grep 选项搜索提交说明中的关键字。
要得到同时满足这两个选项搜索条件的提交,就必须用 --all-match 选项。
-S 列出那些添加或移除了某些字符串的提交。
可以在 git log 选项的最后指定它们的路径。因为是放在最后位置上的选项,所以用两个短划线 – 隔开之前的选项和后面限定的路径名。

  • 列出所有最近两周内的提交
$ git log --since=2.weeks
  • 想找出添加或移除了某一个特定函数的引用的提交
$ git log -Sfunction_name
  • 2018 年 4 月期间,Junio Hamano 提交的但未合并的测试文件
$ git log --pretty="%h - %s" --author=gitster --since="2018-04-01" --before="2018-05-01" --no-merges -- t/

转载地址:https://javaedge.blog.csdn.net/article/details/105511201 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:阿里面试官问我内存池Memory Pool是什么,以为我不知道,其实我都懂!
下一篇:Git版本回退方法论(可能解决你101%遇到的Git版本问题)

发表评论

最新留言

第一次来,支持一个
[***.219.124.196]2024年04月06日 19时11分39秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章