git学习------>如何用git log命令来查看某个指定文件的提交历史记录

简介:        有时候接手一份新代码时,看到某些文件的改动,但不清楚这个改动的作者和原因,想查看该文件的具体提交历史记录。       今天一个同事是这样做的,直接敲git log命令,然后再使用vim命令的搜索关键字的方法来查看该文件的提交记录,如下所示:例如...

       有时候接手一份新代码时,看到某些文件的改动,但不清楚这个改动的作者和原因,想查看该文件的具体提交历史记录。

       今天一个同事是这样做的,直接敲git log命令,然后再使用vim命令的搜索关键字的方法来查看该文件的提交记录,如下所示:

例如:我想查看frameworks/base/packages/SystemUI/AndroidManifest.xml该文件的提交记录,敲了git log命令后,直接按“/”然后加入该文件的路径,后就可以搜索该文件名作为关键字,然后按N和Ctrl+N进行上下搜索结果切换,如下所示:


这样的话,很慢很繁琐,效率比较慢。


下面我介绍一个比较快捷的方法来查看某个指定文件的提交记录,使用的还是git log命令,只是加了一些参数而已。


git log --pretty=oneline 文件名

例如:想搜索刚才的frameworks/base/packages/SystemUI/AndroidManifest.xml文件的提交记录,就可以使用命令:

oyp@buildServer3:~/E580$ git log --pretty=oneline frameworks/base/packages/SystemUI/AndroidManifest.xml
34b7ac981a39193ca78e0d4673ce66515c23988d     [add a new feature to show the battery voltage value and level]     1.Support show the level of 
c1d6879f098775f1d703dfcfe814c4d726be47ad [Create MT6753-6M AP source repository]


如上所示,打印出来的就是针对文件frameworks/base/packages/SystemUI/AndroidManifest.xml文件的所有的改动历史,每一行最前面的那一长串数字就是每次提交形成的哈希值,接下来使用git show即可显示具体的某次的改动的修改。


下面就可以使用git show 命令查看具体的修改详情了。如:

git show <git提交版本号> <文件名>

 git show 34b7ac981a39193ca78e0d4673ce66515c23988d frameworks/base/packages/SystemUI/AndroidManifest.xml
这样指定版本号,指定文件的就可以直接查看该文件的修改详情,不要看该版本号其他文件的修改。如下所示:

oyp@buildServer3:~/E580$ git show 34b7ac981a39193ca78e0d4673ce66515c23988d frameworks/base/packages/SystemUI/AndroidManifest.xml
commit 34b7ac981a39193ca78e0d4673ce66515c23988d
Author: oyp <oyp@runbo.net>
Date:   Mon Nov 30 19:47:48 2015 +0800

        [add a new feature to show the battery voltage value and level]
        1.Support show the level of battery voltage (0-5 levels).
        2.Support show the battery voltage value (accurate to two decimal places).
    
        Appllicable Project: E580
        Appllicable model: All Except IKE
    
        new file:   frameworks/base/packages/SystemUI/res/drawable-hdpi/battery_voltage_0.png
        new file:   frameworks/base/packages/SystemUI/res/drawable-hdpi/battery_voltage_1.png
        new file:   frameworks/base/packages/SystemUI/res/drawable-hdpi/battery_voltage_2.png
        new file:   frameworks/base/packages/SystemUI/res/drawable-hdpi/battery_voltage_3.png
        new file:   frameworks/base/packages/SystemUI/res/drawable-hdpi/battery_voltage_4.png
        new file:   frameworks/base/packages/SystemUI/res/drawable-hdpi/battery_voltage_5.png
        new file:   frameworks/base/packages/SystemUI/src/com/android/systemui/MyBatteryService.java
        new file:   frameworks/base/packages/SystemUI/src/com/android/systemui/MyBootCompletedReceiver.java
    
        modified:   frameworks/base/packages/SystemUI/AndroidManifest.xml
        modified:   frameworks/base/packages/SystemUI/res/layout/system_icons.xml
        modified:   frameworks/base/packages/SystemUI/src/com/android/systemui/statusbar/phone/KeyguardStatusBarView.java
        modified:   frameworks/base/packages/SystemUI/src/com/android/systemui/statusbar/phone/PhoneStatusBar.java
        modified:   frameworks/base/packages/SystemUI/src/com/android/systemui/statusbar/phone/StatusBarHeaderView.java

diff --git a/frameworks/base/packages/SystemUI/AndroidManifest.xml b/frameworks/base/packages/SystemUI/AndroidManifest.xml
old mode 100644
new mode 100755
index dfdc14c..5fb3545
--- a/frameworks/base/packages/SystemUI/AndroidManifest.xml
+++ b/frameworks/base/packages/SystemUI/AndroidManifest.xml
@@ -126,7 +126,11 @@
 
     <!-- M: Add for data sim switch -->
     <uses-permission android:name="android.permission.WRITE_APN_SETTINGS"/>
-
+    
+    <!-- added by ouyang start 2015-11-30 -->
+    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />  
+       <!-- added by ouyang end 2015-11-30 -->
+       
     <application
         android:name=".SystemUIApplication"
         android:persistent="true"
@@ -407,5 +411,14 @@
                 <action android:name="android.intent.action.LOCALE_CHANGED" />
             </intent-filter>
         </receiver>
+        
+        <!-- added by ouyang start 2015-11-30 -->
+        <receiver android:name=".MyBootCompletedReceiver" >
+           <intent-filter>    
+                <action android:name="android.intent.action.BOOT_COMPLETED"/>    
+            </intent-filter>    
+        </receiver>
+        <service android:name=".MyBatteryService"/>
+        <!-- added by ouyang end 2015-11-30 -->
     </application>
 </manifest>



这样的话,很高效、快速的查看指定文件的提交记录和记录详情。


         ====================================================================================

  作者:欧阳鹏  欢迎转载,与人分享是进步的源泉!

  转载请保留原文地址http://blog.csdn.net/ouyang_peng

====================================================================================






相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
7月前
|
开发工具 git
Git版本控制工具合并分支merge命令操作流程
通过以上步聚焦于技术性和操作层面指南(guidance), 可以有效管理项目版本控制(version control), 并促进团队协作(collaboration).
1783 15
|
7月前
|
开发工具 git 开发者
Git版本管理常见文件提交流程讲解
以上就是Git常见文件提交流程概述。掌握此流程对于任何使用Git进行版本控制和协同工作项目团队成员都至关重要。
290 13
|
10月前
|
安全 开发工具 git
git的常用操作命令
git的常用操作命令
583 57
|
8月前
|
存储 缓存 开发工具
Git stash命令的详细使用说明及案例分析。
通过上述案例,我们看到stash命令能够在不丢失进度的情况下,帮助开发者临时切换开发上下文,这在处理多个任务或紧急bug时特别有用。正确使用Git stash可以大大提高开发的灵活性和效率。
2360 0
|
人工智能 前端开发 Java
用git rebase命令合并开发阶段中多条commit提交记录
通过 `git rebase`,可以合并多个提交记录,使开发历史更简洁清晰。操作分为 6 步:查看提交历史 (`git log --oneline`)、设置需合并的提交数 (`git rebase -i HEAD~N`)、修改动作标识为 `s`(squash)、保存退出编辑、调整提交信息、强制推送至远程仓库 (`git push -f`)。此方法适合清理本地无关提交,但若有团队协作或冲突风险,需谨慎使用以避免问题。
2193 60
|
11月前
|
存储 项目管理 开发工具
Git常用命令及操作技巧
以上是Git的常用命令及操作技巧,尽管看起来有些繁琐,但实际上只要花费一些时间进行实践,您将很快熟练掌握。随着使用熟练度的提高,您会发现Git对项目管理和协同工作的强大帮助。
248 20
|
Linux 开发工具 git
版本控制工具:Git的安装和基本命令使用指南。
结束这段探险,掌握了Git你就等于掌握了一个宝藏,随时可以瞥见你的编程历程,轻松面对日后的挑战。Git,无疑是编程者的强大武器,开始你的Git探险之旅吧!
452 28
|
调度
FreeRTOS学习日志 - 第一天
这就是我的FreeRTOS学习日志 - 第一天的内容,明天继续探索这片实时操作系统的广阔海洋。+
227 12
|
开发工具 git 索引
怎么取消对project.private.config.json这个文件的git记录
通过以上步骤,您可以成功取消对 `project.private.config.json`文件的Git记录。这样,文件将不会被包含在未来的提交中,同时仍保留在您的工作区中。
350 28
|
Java 网络安全 开发工具
Git进阶笔记系列(01)Git核心架构原理 | 常用命令实战集合
通过本文,读者可以深入了解Git的核心概念和实际操作技巧,提升版本管理能力。