代码差异对比之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
- 输出结果
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可以获取到项目当前分支下提交前后的代码变动结果,有了这个结果进一步解析可以去做代码覆盖率的实现,在测试阶段可以作为测试覆盖度的一个指标,同时也可以查漏补缺那些业务代码逻辑没有测到,实现精准测试的目的。
- 实际项目中实践如图:
更多测试技术分享、学习资源以及一些其他福利可关注公众号:【Coding测试】获取:
代码差异对比之git diff详解!的更多相关文章
- git diff详解
这篇文章很好很好 https://www.cnblogs.com/alfayed/p/4682780.html
- Git命令详解
一个中文git手册:http://progit.org/book/zh/ 原文:http://blog.csdn.net/sunboy_2050/article/details/7529841 前面两 ...
- Git 命令详解及常用命令
Git 命令详解及常用命令 Git作为常用的版本控制工具,多了解一些命令,将能省去很多时间,下面这张图是比较好的一张,贴出了看一下: 关于git,首先需要了解几个名词,如下: 1 2 3 4 Work ...
- Git应用详解第九讲:Git cherry-pick与Git rebase
前言 前情提要:Git应用详解第八讲:Git标签.别名与Git gc 这一节主要介绍git cherry-pick与git rebase的原理及使用. 一.Git cherry-pick Git ch ...
- Git初探--笔记整理和Git命令详解
几个重要的概念 首先先明确几个概念: WorkPlace : 工作区 Index: 暂存区 Repository: 本地仓库/版本库 Remote: 远程仓库 当在Remote(如Github)上面c ...
- 【Git使用详解】Egit的常用操作详解
常用操作 操作 说明 Fetch 从远程获取最新版本到本地,不会自动merge Merge 可以把一个分支标签或某个commit的修改合并现在的分支上 Pull 从远程获取最新版本并merge到本地相 ...
- git部署详解
1.1 关于版本控制 1.1.1 本地版本控制 本地版本控制系统 许多人习惯用复制整个项目目录的方式来保存不同的版本,或许还会改名加上备份时间以示区别.这么做唯一的 好处就是简单,但是特别容易犯错.有 ...
- ORM框架对比以及Mybatis配置文件详解
ORM框架对比以及Mybatis配置文件详解 0.数据库操作框架的历程 (1) JDBC JDBC(Java Data Base Connection,java数据库连接)是一种用于执行SQL语句 ...
- iOS开发——开发实战篇&版本控制SVN和Git使用详解
版本控制SVN和Git使用详解 公司的实际开发中,在天朝使用较多的还是SVN,因为SVN是集中式的,在天朝上班你们都懂的! -----------------svn--------- ...
- git命令详解( 四 )
此篇为git命令详解的第四篇,话不多说,我们直接上知识点好吧 git Push 偏离的工作 gitPush: 此命令负责将你的变更上传到指定的远程仓库,并在远程仓库上合并你的新提交记录.一旦 git ...
随机推荐
- 如何将一个模块文件编译到Linux内核中?
很多粉丝在群里提问,如何把一个模块文件编译到内核中或者独立变异成ko文件.本文给大家详解讲解. 1. 内核目录 Linux内核源代码非常庞大,随着版本的发展不断增加.它使用目录树结构,并且使用Make ...
- Python 开发中,使用bcrypt 或 Passlib 对系统用户密码进行哈希和验证处理
在设计一个系统的时候,肯定都有会有用户身份认证的问题,一般对用户校验的时候,都是对用户存在数据库总的密码哈希值进行判断,从而避免密码泄露和反向解密,那么在Python 开发中,我们可以引入bcrypt ...
- TCP/TP协议栈(逐渐更新版)
TCP/IP协议栈 应用层 DNS协议 传输层 TCP协议 TCP协议报文结构 源端口 目的端口 序列号 确认号 头长度header length or data offset 保留字段reserve ...
- 安装 Ubuntu / Windows 双系统
最近给自己的老笔记本换了一块大硬盘,顺便装了 Windows 和 Ubuntu 两个操作系统.记录一下安装过程. 提示:Ubuntu 安装程序可以检测到磁盘已有的 Windows 安装.所以如果先安装 ...
- MSYS2、MinGW、Cygwin 关系梳理
还记得大一刚开始写 C 代码时,经常看到 MSYS2.MinGW.Cygwin 等名词.对于第一次接触编程的我来说这些名词让我眼花缭乱.当时查阅了一些资料,但是对于这些名词的解释始终让我云里雾里.现在 ...
- 3d格式介绍之OBJ格式
OBJ格式是一种用于3D模型的文件格式,全称为Wavefront OBJ.它由Wavefront Technologies公司开发,最初用于其高级视觉动画软件,但后来广泛应用于各种3D图形软件中. 本 ...
- springboot 大文件切片上传
1. 前端(vue element ui & 原生) 初始变量声明: currentFile: {}, // 当前上传的文件 bigFileSliceCount: 20, // 大文件切片后的 ...
- AWS Data Analytics Fundamentals 官方课程笔记 - Intro, Volumn, Velocity
Intro process 就是 The process component is where services manipulate data into needed forms. 比如补齐 nul ...
- PageHeper
PageHelper 是一个非常流行的 MyBatis 分页插件,主要用于简化分页查询的实现.使用 PageHelper 可以在执行数据库查询时,自动处理分页参数,从而避免手动编写繁琐的分页逻辑. 今 ...
- 【QT界面美化】QT界面美化效果截图QSS+QML
贴几个QT做的界面美化效果截图. 先来一张动图,有一些画面是QT Widgets + QSS实现的:另外一些画面是QT QML实现的. QT界面美化效果图QT QSS QML 补天云QT技术培训专家 ...