代码差异对比之git diff详解!

代码差异对比之git diff详解!

1、测试对比文件准备

  • 文件A:diff1(diff1文件夹下可以放n个文件)

public class Diff1 {
    public static void main(String[] args){
        int getNum = randomNumber(10,20);
        if (getNum==30){
            System.out.println("中间数="+getNum);
        }else {
            System.out.println("此次没有找到="+getNum);
        }
    }
    public static int randomNumber(int minNum,int maxNum){
        Random rand = new Random();
        int randomNum = rand.nextInt(maxNum);
        randomNum = randomNum%(maxNum-minNum+1)+minNum;
        return randomNum;
    }
}
  • 文件B:diff2(diff2文件夹下可以放n个文件)
public class Diff2 {
    public static void main(String[] args){
        int addLine =10;
        int getNum = randomNumber(10,20);
        if (getNum==30){
            System.out.println("中间数="+getNum);
        }else {
//            System.out.println("此次没有找到="+getNum);
        }
    }
    public static int randomNumber(int minNum,int maxNum){
        Random rand = new Random();
        int randomNum = rand.nextInt(maxNum);
        randomNum = randomNum%(maxNum-minNum+1)+minNum;
        return randomNum;
    }
}

2、git diff对比命令

diff --git /Users/diff1 /Users/diff2

代码差异对比之git diff详解!

  • 输出结果
    代码差异对比之git diff详解!
diff --git a/Users/cuizhongyuan/Desktop/work/010_project/vueSpringboot/Tal_Back/src/test/java/gitdiff/diff1/Diff1.java b/Users/cuizhongyuan/Desktop/work/010_project/vueSpringboot/Tal_Back/src/test/java/gitdiff/diff2/Diff2.java
similarity index 77%
rename from /Users/cuizhongyuan/Desktop/work/010_project/vueSpringboot/Tal_Back/src/test/java/gitdiff/diff1/Diff1.java
rename to /Users/cuizhongyuan/Desktop/work/010_project/vueSpringboot/Tal_Back/src/test/java/gitdiff/diff2/Diff2.java
index 7d6e724..bfca53f 100644
--- a/Users/cuizhongyuan/Desktop/work/010_project/vueSpringboot/Tal_Back/src/test/java/gitdiff/diff1/Diff1.java
+++ b/Users/cuizhongyuan/Desktop/work/010_project/vueSpringboot/Tal_Back/src/test/java/gitdiff/diff2/Diff2.java
@@ -1,14 +1,15 @@
-package gitdiff.diff1;
+package gitdiff.diff2;
 
 import java.util.Random;
 
-public class Diff1 {
+public class Diff2 {
     public static void main(String[] args){
+        int addLine =10;
         int getNum = randomNumber(10,20);
         if (getNum==30){
             System.out.println("中间数="+getNum);
         }else {
-            System.out.println("此次没有找到="+getNum);
+//            System.out.println("此次没有找到="+getNum);
         }
     }
     public static int randomNumber(int minNum,int maxNum){

3、输出格式详解(重点)

  • 第一行
diff --git a/Users/diff1/Diff1.java b/Users/diff2/Diff2.java

解释:进行比较的是->diff1版本的Diff1.java(即变动前)和diff2版本的Diff2.java(即变动后)

  • 第二行
index 7d6e724..bfca53f 100644

解释:表示两个版本的git哈希值(index区域的7d6e724对象,与工作目录区域的bfca53f对象进行比较),最后的六位数字是对象的模式(普通文件,644权限)

  • 第三行
--- a/Users/diff1/Diff1.java+++ b/Users/diff2/Diff2.java

解释:"—“表示变动前的版本,”+++"表示变动后的版本

  • 第四行
@@ -1,14 +1,15 @@

解释:其中"-1,14″分成三个部分解释->”-“减号表示第一个文件(即diff1),"1″表示第1行,“14″表示连续14行.合在一起,就表示下面是第一个文件从第1行开始的连续14行.同样的,”+1,15″表示变动后,成为第二个文件从第1行开始的连续15行

  • 最后是具体的变动内容
-public class Diff1 {
+public class Diff2 {
     public static void main(String[] args){
+        int addLine =10;
         int getNum = randomNumber(10,20);
         if (getNum==30){
             System.out.println("中间数="+getNum);
         }else {
-            System.out.println("此次没有找到="+getNum);
+//            System.out.println("此次没有找到="+getNum);
         }
     }
     public static int randomNumber(int minNum,int maxNum){

解释:+ int addLine =10;->表示:新增行
| - System.out.println(“此次没有找到=”+getNum);
+// System.out.println(“此次没有找到=”+getNum); ->表示改行的变动(- 表示之前,+表示之后)git diff 没有修改的概念

4、获取到git diff对比结果可以做什么?

通过Git diff可以获取到项目当前分支下提交前后的代码变动结果,有了这个结果进一步解析可以去做代码覆盖率的实现,在测试阶段可以作为测试覆盖度的一个指标,同时也可以查漏补缺那些业务代码逻辑没有测到,实现精准测试的目的。

  • 实际项目中实践如图:

代码差异对比之git diff详解!



更多测试技术分享、学习资源以及一些其他福利可关注公众号:【Coding测试】获取:
代码差异对比之git diff详解!

上一篇:git 修改大小写远程分支失败


下一篇:20220215