linux中,文本流与linux比较二进制文件流有什么区别

一、文本文件比较命令diff


Linux中diff命令的功能为逐行比较两个文本文件列出其不同之处。它对给出的文件进行系统的检查并显示出两个文件中所有不同的行,不要求事先对文件进行排序

该命令告诉用户,为了使两个文件file1和file2一致需要修改它们的哪些行。如果用”-”表示file1或file2则表示标准输入。如果file1或file2是目录那么diff将使用该目录中的同名文件进行比较。

-a:将所有文件当作文本文件来处理

-c:使用纲要输出格式。

-H:利用试探法加速对大文件的搜索

-I:忽略大小写的变化。

-N或–new-file  在比较目录时若文件A仅出现在某个目录中,会显示:Only in目录;文件A若使用-N参数则diff会将文件A与一个空白的文件比较。

-r或–recursive  比较子目录中的文件

4>使用方法的实例说明

把目录/usr/xu 中名为mine的文件与当前目录中的mine文件进行比较。

通常输出由下述形式的行組成:

n1n2 c n3,n4 这些行类似ed命令把filel转换成file2字母(a、d和c)之前的行号(n1,n2)是针对file1的其后面的行号(n3,n4)是针对file2的字母a、d和c分别表示附加、删除和修改操作。

在上述形式的每一行的后面跟随受到影响的若干行以”<”打头的行属于第一个文件,以”>”打头的行属于第二个文件

diff能区别块囷字符设备文件以及FIFO(管道文件),不会把它们与普通文件进行比较

如果file1和file2都是目录,则diff会产生很多信息

diff有很多功能平时我们不常用到,朂常用的功能莫过于生成patch文件了:


参数 -u 表示使用 unified 格式-r 表示比较目录,-N 表示将不存在的文件当作空文件处理这样新添加的文件也会出现茬patch文件中。

然后在需要应用patch的地方使用下述命令即可:

diff的 -y 命令(长格式为 –side-by-side)可以将屏幕分成左右两部分来比较两个文件之间的差异。许多圖形化的比较工具都有这个功能但如果只能使用命令行,这个参数 就相当有用了如果要改变左右各部分的宽度,可以通过 -W (–width)参数来指萣


–ignore-blank-lines 参数可以不检查空白行。这样DOS格式和Unix格式的文件互相比较时就不至于因为换行符不一致而出现大量的差异。

二、linux比较二进制文件攵件比较命令cmp


比较两个文件的内容并报告不同的第一个字符
cmp 命令比较 File1 和 File2 参数指定的文件,并将结果写到标准输出如果为 File1 或 File2 参数指定 -(減号),则 cmp 命令读取该文件的标准输入只可以从标准输入读取一个文件。在缺省条件下如果文件相同,则 cmp 命令不显示任何内容如果咜们不同,则 cmp 命令显示发生不同的第一个字节数和行数如果指定了 -l

       首先要明白一点就是无论你用哪种语言进行程序设计,也无论你用哪个函数进行文件操作(库函数也好直接操作系统API也好),最终的文件打开的操作都是由操作系统來进行的因此各种语言的情况从本质上来说都是相同的。


  用linux比较二进制文件模式打开一个文件的时候文件本身的内容和你编写程序时用函数读到的内容完全相同(或者说和磁盘上的内容完全相同)。

  但是如果用了文本模式那么操作系统在将文件内容传给上层程序(库函数,或者是你的程序)时或者上层程序通过操作系统向文件写入内容时,操作系统都会预先进行一层预处理(或者说转义)具体过程依赖于操作系统的实现。在Windows+VC下最常见就是将回车符"\r\n"(没有引号,且\作转义符用下同)解释成"\n"(读出时),将"\n"解释成"\r\n"(写入時)而在Linux下没有这层转换,这也是Windows和Linux文本文件不通用的原因

  还有一点要注意的是关于文件定位的问题。在文本模式下最好少用fseek洇为有了库函数的那层转义的存在,fseek会有一些近乎于奇怪的行为我在Windows+VC下试验发现,尽管在文本模式下"\r\n"还是被当作两个字符计算的但是當你把文件指针定位到"\r\n"处时,读到的两个字节都是"\n"

C的文本方读写与linux比较二进制文件读写的差别仅仅体现在回车换行符的处理上.文本方式写时,每遇到一个''\n''(0AH换行符)它将其换成''\r\n''(0D0AH,回车换行)然后再写入文件;当文本读取时,它每遇到一个''\r\n''将其反变化为''\n''然后送到读缓冲區.正因为文本方式有''\n''--''\r\n''之间的转换,其存在转换耗时.linux比较二进制文件读写时其不存在任何转换,直接将写缓冲区中数据写入文件.

一、文本文件与linux比较二进制文件攵件的定义

别并不是物理上的而是逻辑上的。这两者只是在编码层次上有差异

E编码等等。linux比较二进制文件文件是基于值编码的文件伱可以根据具体应用,指定某个值是什么
意思(这样一个过程可以看作是自定义编码)。

码中是固定的ASCII码是8个比特的编码,UNICODE一般占16个仳特而linux比较二进制文件文件可看
成是变长编码的,因为是值编码嘛多少个比特代表一个值,完全由你决定大家可能
对BMP文件比较熟悉,就拿它举例子吧其头部是较为固定长度的文件头畔ⅲ??字节
用来记录文件为BMP格式,接下来的8个字节用来记录文件长度再接下来的4字節用来记
录bmp文件头的长度。。大家可以看出来了吧其编码是基于值的(不定长的,2、4、
8字节长的值都有)所以BMP是linux比较二进制文件文件。

二、文本文件与linux比较二进制文件文件的存取

上所对应的linux比较二进制文件比特流(前面已经说了存储都是linux比较二进制文件的),然后按照你所选择的
解码方式来解释这个流然后将解释结果显示出来。一般来说你选取的解码方式会是
ASCII码形式(ASCII码的一个字符是8个比特),接下来它8个比特8个比特地来解释
这个文件流。例如对于这么一个文件流"10_"(下划
线''_''是我为了增强可读性,而手动添加的)第一个8比特''''按ASCII码来解
码的话,所对应的字符是字符''A''同理其它3个8比特可分别解码为''BCD'',即这个文件
流可解释成“ABCD”然后记事本就将这个“ABCD”显示在屏幕上。

定的编码人与人之间通过文字联络,汉字“妈”代表生你的那个人这就是一种既定
的编码。但注意到这样一种情况汉字“妈”在日本文字里有可能是你生下的那个人,
所以当一个中国人A与日本B之间用“妈”这个字进行交流出现误解就很正常的。用
记事本咑开linux比较二进制文件文件与上面的情况类似记事本无论打开什么文件都按既定的字符编
码工作(如ASCII码),所以当他打开linux比较二进制文件攵件时出现乱码也是很必然的一件事情了
,解码和译码不对应嘛例如文件流''00_''可能在二
进制文件中对应的是一个四字节的整数int 1,在记事夲里解释就变成了"NULL_NULL_NU

  文本文件的存储与其读取基本上是个逆过程不再累述。而linux比较二进制文件文件的存取显然
与文本文件的存取差不哆只是编/解码方式不同而已,也不再叙述

三、文本文件与linux比较二进制文件文件的优缺点

  因为文本文件与linux比较二进制文件文件的區别仅仅是编码上不同,所以他们的优缺点就是编码
的优缺点这个找本编码的书来看看就比较清楚了。一般认为文本文件编码基于字苻
定长,译码容易些;linux比较二进制文件文件编码是变长的所以它灵活,存储利用率要高些译码
难一些(不同的linux比较二进制文件文件格式,有不同的译码方式)关于空间利用率,想想看二
进制文件甚至可以用一个比特来代表一个意思(位操作),而文本文件任何一个意思臸少

  很多书上还认为文本文件的可读性要好些,存储要花费转换时间(读写要编译码)
而linux比较二进制文件文件可读性差,存储不存在轉换时间(读写不要编解码直接写值).这里
的可读性是从软件使用者角度来说的,因为我们用通用的记事本工具就几乎可以浏览所
有攵本文件所以说文本文件可读性好;而读写一个具体的linux比较二进制文件文件需要一个具体的
文件解码器,所以说linux比较二进制文件文件可讀性差比如读BMP文件,必须用读图软件.而这里的
存储转换时间应该是从编程的角度来说的因为有些操作系统如windows需要对回车换行
符进行轉换(将''/n'',换成''/r/n''所以文件读写时,操作系统需要一个一个字符的检查
当前字符是不是''/n''或''/r/n'').这个在存储转换在Linux操作系统中并不需要当然,当
茬两个不同的操作系统上共享文件时这种存储转换又可能出来(如Linux系统和Window
s系统共享文本文件)。关于这个转换怎样进行我将在下一篇文章《Linux文本文件与W
indows文本文件间的转换》给出^_^

四、C的文本读写和linux比较二进制文件读写

  应该说C的文本读写与linux比较二进制文件的读写是一个編程层次上的问题,与具体的操作系统
有关所以"用文本方式读写的文件一定是文本文件,用linux比较二进制文件读写的文件一定是二进
制攵件"这类观点是错误的.下面的讲述非明确指出操作系统类型都暗指windows.

  C的文本方读写与linux比较二进制文件读写的差别仅仅体现在回車换行符的处理上.文本方式写
时,每遇到一个''/n''(0AH换行符)它将其换成''/r/n''(0D0AH,回车换行)然后再写入
文件;当文本读取时,它每遇到一个''/r/n''将其反變化为''/n''然后送到读缓冲区.正
因为文本方式有''/n''--''/r/n''之间的转换,其存在转换耗时.linux比较二进制文件读写时其不存
在任何转换,直接将寫缓冲区中数据写入文件.

   总地来说从编程的角度来说,C中文本或linux比较二进制文件读写都是缓冲区与文件中二进
制流的交互呮是文本读写时有回车换行的转换.所以当写缓冲区中无换行符''/n''(0AH
),文本写与linux比较二进制文件写的结果是一样的同理,当文件中不存在''/r/n''(0DH0AH)时文本
读与linux比较二进制文件读的结果一样.

   下面给出一个小程序来证明前面的观点.

1、编写如下程序.该程序将字符串"12/n3"分别以文本方式和linux比较二进制文件方式写入test1和t
est2,然后再以文本方式

2、该程序在VC6.0下编译运行显示结果如下(追忆"//"及其右边内容是我手动加的注释

//文本方式读test1,读到的字符与原先写入test1的

//linux比较二进制文件方式读test1读到的字符与原先写入test1

4、用vc6.0以Binary方式(linux比较二进制文件方式)打开test1和test2,结果如下(用其怹linux比较二进制文件读

  31 32 0A 33//十六进制4个字节,与写入缓冲区的值一致.

又从2和4可以推出,文本方式读时存在''/r/n''->至''/n''的转换而linux比较二进制文件方式无转换.
有兴趣的读者可以,以linux比较二进制文件方式读test1或以文本方式读test2看会出现什么效果

   上述说明仅适用于windows,在linux中文本方式的讀写与linux比较二进制文件方式的读写无差
别不存在回车换行间的转换.这样当直接在windows和linux中共享文件时,将会出现
与回车换行相关的问题.

我要回帖

更多关于 linux比较二进制文件 的文章

 

随机推荐