1 命令格式

$diff <变动之前的文件> <变动之后的文件>

2 diff文件的三种格式

normal diff

context diff

unified diff

3 示例

变动之前的文件:

b

bc

b

b

b

每行一个b,共5行。

变动之后的文件:

b

bcd

b

b

b

共5行,第二行一个d,其它行都是b。

4 正常格式的diff

这个diff输出的只有difference本身,不包括difference所在的代码本身。

diff f1.txt f2.txt

输出如下:

2c2

< bc

------

> bcd

第一行说明变动的位置:前面的2是前面文件中的位置,后面一个2是后面文件中的位置,表示行号。

c表示change,即内容改变,如果是a的话,表示该行是新增加的,如果是d的话,表示该行被删除了。

小于号“<”表示删除该行,大于号">"表示增加该行。小于号和大于号后面的内容是该行的内容。

5 context diff

diff -c f1.txt f2.txt

输出如下:

*** f1.txt    2016-12-25 23:53:02.619930781 -0500

--- f2.txt      2016-12-25 23:52:54.131930652 -0500

***************************

*** 1,5 ***

b

!bc

b

b

b

---1,5---

b

!bcd

b

b

b

前面两行是两个文件的基本信息,即文件名和时间,后面是时区。并且,*表示是旧的文件,-表示的是新的文件。

***1,5***表示1到5行的所有内容。对于---1,5---同样。

!表示本行的内容有改变。同样,a表示增加一行,d表示减少一行。

可见,对于context格式的输出而言,f1和f2文件的上下文是分别显示的,

因此有很多重复的内容,因此有了unified格式,也就是说,f1和f2公用同

一个上下文。

6 unified diff

$ diff -u f1.txt f2.txt

输出如下:

--- f1.txt        2016-12-25 23:53:02.619930781 -0500

+++ f2.txt      2016-12-25 23:52:54.131930652 -0500

@@ -1,5 +1,5 @@

b

-bc

+bcd

b

b

b

-表示f1.txt文件,+表示f2.txt文件。

1,5表示第1行到第5行。

1,5表示第1行到第5行。

-表示原文件的行,+表示新文件的行。

所以,只看-的话就是原文件,只看+的话,就是新文件了。

diff输出格式解析的更多相关文章

  1. (待补充)diff 算法解析

    今天,学习React的时候,底层提到了 diff算法,顺藤摸瓜, 也发现了VUE也使用了diff算法. mark一下,后续补充 infoq-VUE-diff算法 react-diff算法

  2. 解析vue2.0的diff算法 虚拟DOM介绍

    react虚拟dom:依据diff算法台 前端:更新状态.更新视图:所以前端页面的性能问题主要是由Dom操作引起的,解放Dom操作复杂性 刻不容缓 因为:Dom渲染慢,而JS解析编译相对非常非常非常快 ...

  3. git diff与linux diff的输出格式之unified format

    前言 前面有一篇文章<一个有些意思的项目--文件夹对比工具(一)>,里面简单讲了下diff算法之--Myers算法. 既然是算法,就会有实现,比如git diff中有Myers的实现,gi ...

  4. 虚拟dom与diff算法 分析

    好文集合: 深入浅出React(四):虚拟DOM Diff算法解析 全面理解虚拟DOM,实现虚拟DOM

  5. diff 比较两个文件的差异

    功能:比较两个文件的差异,并把不同地方的信息显示出来.默认diff格式的信息. diff比较两个文件或文件集合的差异,并记录下来,生成一个diff文件,这也是我们常说的补丁文件.也使用patch命令对 ...

  6. linux常用命令--diff

    diff是Unix系统的一个很重要的工具程序. 它用来比较两个文本文件的差异,是代码版本管理的基石之一.你在命令行下,输入: $ diff <变动前的文件> <变动后的文件> ...

  7. ReactiveNative学习之Diff算法

    React 源码剖析系列 - 不可思议的 react diff深入浅出React(四):虚拟DOM Diff算法解析React diff 算法总结链接引用的文章React出于性能的考虑,为了避免频繁操 ...

  8. diff比较两个文件 linux

    功能:比较两个文件的差异,并把不同地方的信息显示出来.默认diff格式的信息. diff比较两个文件或文件集合的差异,并记录下来,生成一个diff文件,这也是我们常说的补丁文件.也使用patch命令对 ...

  9. 虚拟DOM解析及其在框架里的应用

    虚拟DOM解析及其在框架里的应用 浏览器是怎样解析HTML并且绘出整个页面的 上图为webkit引擎浏览器的处理流程,如上图大致分为4大步: 第一步,HTML解析器分析html,构建一颗DOM树: 第 ...

随机推荐

  1. .NET简谈接口

    自从面向对象开发方式的出现,抽象的概念就开始日新月异的发展,面向对象编程.面向接口编程.面向组件编程等等:这一系列的概念都是软件工程所追求的思想范畴,高类聚低耦合. 今天我要简谈的是面向对象里面非常重 ...

  2. 如何解决google ping不通的问题。

    1. 用http://ping.chinaz.com/ ping google的域名. 2. 会ping出很多ip,但是chinaz用的是测试网点去ping的,不是你本地宽带, 所以把ping出ip拷 ...

  3. ArcEngine奇怪异常:HRESULT:0x80040351

    错误如图 根据该博客,http://blog.csdn.net/u011609113/article/details/51155116, 显示该错误为Duplicate Field Names wit ...

  4. SQL查询到的数据放到DataSet中

    public DataTable GetTable(string Id) { StringBuilder strSql = new StringBuilder(); DataSet ds = new ...

  5. linux常用命令(三)

    文件搜索命令 which 命令;可以用于查询某个命令所存在的路径,由此可知道谁可以使用它.附加可以看到命令的别名记录,就是在ls的时候会自动对文件夹上色.前面章节讲过. whereis 命令;可以找到 ...

  6. Linux下安装Git

    Ubuntu12.04中默认没有安装Git.需要自行安装. 1. 安装Git 1.1 Ubuntu12.04下 可以使用apt-get方式安装,也可以下载源代码安装[1],我们这里使用apt-git安 ...

  7. 神经网络之Hebb学习规则

  8. 配置Office 365单点登录摘要

    O365: 如果O365账号之前做过测试,则停用同步,强制删除已有用户涉及命令:Remove-MsolUser -UserPrincipalName zhang_san@company.cn (-Re ...

  9. 为Office365增加密码过期自动提醒功能

    最近有人和我反应,无法查看所有员工的Office365的密码过期时间.最好可以批量查看,如果能在过期前几天发个提醒邮件就更好了. $pw = ConvertTo-SecureString 'your_ ...

  10. 更换Mac记录

    1. 重装Mac (1)格式化硬盘 (2)重装系统 (3)修改各种配置:电脑名.键盘等 2. 安装必要软件 (1)QQ.微信.网易云音乐等 (2)火狐.谷歌.SourceTree等 (3)安装Git ...