- 浏览: 46183 次
- 性别:
- 来自: 北京
最新评论
网上关于文本文件与二进制文件的文章很多,但遗憾的是,这些文章讲得都比较散。下面我将结合所查到的资料,从多个角度谈谈文本文件与二进制文件。
一、文本文件与二进制文件的定义
大家都知道计算机的存储在物理上是二进制的,所以文本文件与二进制文件的区别并不是物理上的,而是逻辑上的。这两者只是在编码层次上有差异。简单来说,文本文件是基于字符编码的文件,常见的编码有ASCII编码,UNICODE编码等等。二进制文件是基于值编码的文件,你可以根据具体应用,指定某个值是什么意思(这样一个过程,可以看作是自定义编码)。
从上面可以看出文本文件基本上是定长编码的,基于字符嘛,每个字符在具体编码中是固定的,ASCII码是8个比特的编码,UNICODE一般占16个比特。而二进制文件可看成是变长编码的,因为是值编码嘛,多少个比特代表一个值,完全由你决定。大家可能对BMP文件比较熟悉,就拿它举例子吧,其头部是较为固定长度的文件头信息,前2字节用来记录文件为BMP格式,接下来的8个字节用来记录文件长度,再接下来的4字节用来记录bmp文件头的长度。。。大家可以看出来了吧,其编码是基于值的(不定长的,2、4、8字节长的值都有),所以BMP是二进制文件。
二、文本文件与二进制文件的存取
文本工具打开一个文件的过程是怎样的呢?拿记事本来说,它首先读取文件物理上所对应的二进制比特流(前面已经说了,存储都是二进制的),然后按照你所选择的解码方式来解释这个流,然后将解释结果显示出来。一般来说,你选取的解码方式会是ASCII码形式(ASCII码的一个字符是8个比特),接下来,它8个比特8个比特地来解释这个文件流。例如对于这么一个文件流"01000000_01000001_01000010_01000011"(下划线''_'',是我为了增强可读性,而手动添加的),第一个8比特''01000000''按ASCII码来解码的话,所对应的字符是字符''A'',同理其它3个8比特可分别解码为''BCD'',即这个文件流可解释成“ABCD”,然后记事本就将这个“ABCD”显示在屏幕上。
事实上,世界上任何东西要与其他东西通信会话,都存在一个既定的协议,既定的编码。人与人之间通过文字联络,汉字“妈”代表生你的那个人,这就是一种既定的编码。但注意到这样一种情况,汉字“妈”在日本文字里有可能是你生下的那个人,所以当一个中国人A与日本B之间用“妈”这个字进行交流,出现误解就很正常的。用记事本打开二进制文件与上面的情况类似。记事本无论打开什么文件都按既定的字符编码工作(如ASCII码),所以当他打开二进制文件时,出现乱码也是很必然的一件事情了,解码和译码不对应嘛。例如文件流''00000000_00000000_00000000_00000001''可能在二进制文件中对应的是一个四字节的整数int 1,在记事本里解释就变成了"NULL_NULL_NULL_SOH"这四个控制符。
文本文件的存储与其读取基本上是个逆过程,不再累述。而二进制文件的存取显然与文本文件的存取差不多,只是编/解码方式不同而已,也不再叙述。
三、文本文件与二进制文件的优缺点
因为文本文件与二进制文件的区别仅仅是编码上不同,所以他们的优缺点就是编码的优缺点,这个找本编码的书来看看就比较清楚了。一般认为,文本文件编码基于字符定长,译码容易些;二进制文件编码是变长的,所以它灵活,存储利用率要高些,译码难一些(不同的二进制文件格式,有不同的译码方式)。关于空间利用率,想想看,二进制文件甚至可以用一个比特来代表一个意思(位操作),而文本文件任何一个意思至少是一个字符.
很多书上还认为,文本文件的可读性要好些,存储要花费转换时间(读写要编译码),而二进制文件可读性差,存储不存在转换时间(读写不要编解码,直接写值).这里的可读性是从软件使用者角度来说的,因为我们用通用的记事本工具就几乎可以浏览所有文本文件,所以说文本文件可读性好;而读写一个具体的二进制文件需要一个具体的文件解码器,所以说二进制文件可读性差,比如读BMP文件,必须用读图软件.而这里的存储转换时间应该是从编程的角度来说的,因为有些操作系统如windows需要对回车换行符进行转换(将''\n'',换成''\r\n'',所以文件读写时,操作系统需要一个一个字符的检查
当前字符是不是''\n''或''\r\n'').这个在存储转换在Linux操作系统中并不需要,当然,当在两个不同的操作系统上共享文件时,这种存储转换又可能出来(如Linux系统和Windows系统共享文本文件)。
四、C的文本读写和二进制读写
应该说C的文本读写与二进制的读写是一个编程层次上的问题,与具体的操作系统有关,所以"用文本方式读写的文件一定是文本文件,用二进制读写的文件一定是二进制文件"这类观点是错误的.
下面的讲述非明确指出操作系统类型,都暗指windows.C的文本方读写与二进制读写的差别仅仅体现在回车换行符的处理上.文本方式写时,每遇到一个''\n''(0AH换行符),它将其换成''\r\n''(0D0AH,回车换行),然后再写入文件;当文本读取时,它每遇到一个''\r\n''将其反变化为''\n'',然后送到读缓冲区.正因为文本方式有''\n''--''\r\n''之间的转换,其存在转换耗时.二进制读写时,其不存在任何转换,直接将写缓冲区中数据写入文件.
总地来说,从编程的角度来说,C中文本或二进制读写都是缓冲区与文件中二进制流的交互,只是文本读写时有回车换行的转换.所以当写缓冲区中无换行符''\n''(0AH),文本写与二进制写的结果是一样的,同理,当文件中不存在''\r\n''
(0DH0AH)时,文本读与二进制读的结果一样.
下面给出一个小程序来证明前面的观点.
1、编写如下程序.该程序将字符串"12\n3"分别以文本方式和二进制方式写入test1和test2,然后再以文本方式
读test1,以二进制方式读test2.
#include<stdio.h> int main() { FILE * fp_text,* fp_binary; char write_buf[4]={'1','2','\n','3'}; char read_buf_text[6],read_buf_binary[6]; int read_count_text,read_count_binary; //未检测打开是否失败 fp_text=fopen("test1","wt+"); fp_binary=fopen("test2","wb+"); fwrite(write_buf,4,1,fp_text); fwrite(write_buf,4,1,fp_binary); //fflush(fp_text); //fflush(fp_binary); fseek(fp_text,0L,SEEK_SET);//fseek附带了fflush功能 fseek(fp_binary,0L,SEEK_SET);// read_count_text=fread(read_buf_text,sizeof(char),5,fp_text); read_count_binary=fread(read_buf_binary,sizeof(char),5,fp_binary); //加''\0'',便于打印字符串 read_buf_text[read_count_text]='\0'; read_buf_binary[read_count_binary]='\0'; printf("In Text Mode:read_count=%d,string=%s\n",read_count_text,read_buf_text); printf("In Binary Mode:read_count=%d,string=%s\n",read_count_binary,read_buf_binary); fclose(fp_text); fclose(fp_binary); return 0; }
2、该程序在VC6.0下编译运行,显示结果如下(追忆"\\"及其右边内容是我手动加的注释):
In Text Mode:read_count=4,string=12
3 //文本方式读test1,读到的字符与原先写入test1的字符一样
In Binary Mode:read_count=4,string=12
3 //二进制方式读test1,读到的字符与原先写入test2的字符一样
3、用记事本打开test1和test2,结果如下:
test1的内容:
12
3 //文本方式写入的,有换行效果,参看下面的4
test2的内容
123 //二进制方式写入的,无换行效果(记事本对"\r\n"之外的控制字符串无显示效果),参看下面的4
4、用vc6.0以Binary方式(二进制方式)打开test1和test2,结果如下(用其他二进制读写软件也可以)
test1的内容
31 32 0D 0A 33//十六进制,5个字节,比写入缓冲区多了一个字节,在''\n''(0AH)前插了一个''\r''(0DH)
test2的内容
31 32 0A 33//十六进制,4个字节,与写入缓冲区的值一致.
5、总结
从4可以看出,文本方式写时,存在''\n''->''\r\n''的转换,而二进制方式无转换.又从2和4可以推出,文本方式读
时存在''\r\n''->至''\n''的转换,而二进制方式无转换.有兴趣的读者可以,以二进制方式读test1或以文本方式读
test2,看会出现什么效果.
6.补充说明
上述说明仅适用于windows,在linux中文本方式的读写与二进制方式的读写无差别,不存在回车换行间的转换.这
样当直接在windows和linux中共享文件时,将会出现与回车换行相关的问题.
文章出处:飞诺网(www.firnow.com):http://dev.firnow.com/course/3_program/c++/cppsl/2008121/96899.html
发表评论
-
VC下使用Macro (vbs)来实现标准注释的自动添加
2010-11-15 10:40 1951在VC6.0中,Tools->Macro可以直接录制宏, ... -
TCP/UDP包大小
2010-10-29 14:22 1785UDP一次发送数据包的大小,TCP一次发送数据包的大小。MTU ... -
Excel文件操作类
2010-09-06 10:50 1119Excel文件操作封装类 可实现以下功能: 1、打开已有E ... -
Visual C++ 6.0 操作excel2003进行图表绘制
2010-08-13 13:38 5252在实现对excel2003进行读写的基础之上,可以实现exce ... -
【转】Visual C++ 6.0 实现对excel2003的读写
2010-08-13 09:35 48221. 导入excel.h,excel.cpp文件 具 ... -
【转】VC++6.0共享内存
2010-08-04 09:25 2143VC++6.0共享内存技术总结 程序1 -- 建立共享区,写 ... -
【转】VC++中进程间相互通信的十一种方法
2010-08-04 09:05 1718进程通常被定 ... -
【转】多线程技术在VC++串口通信程序中的应用研究
2010-08-04 09:00 33661. 概述 在现代的各种实时监控系统和通信系统 ... -
【转】虚拟机(VMware)ubuntu9.04下挂载windows硬盘
2010-08-04 08:35 2170以挂载 F 盘 为例: 1. 关闭ubuntu。 ... -
技术备忘录之十一
2009-09-02 17:23 9302009-09-02 CONE 36 Panic的 ... -
技术备忘录之十
2009-09-02 17:13 9532009-09-01 symbian中的Log文件 ... -
技术备忘录之九
2009-09-02 17:08 11642009-08-26 symbian SDK第一次 ... -
技术备忘录之八
2009-08-09 20:18 8612009-08-09 VC中全局变量的定义- ... -
技术备忘录之七
2009-08-07 21:39 9772009-08-07 VC中文件读写 今天花了几个小 ... -
技术备忘录之六
2009-08-06 23:02 7922009-08-06 carbide中导入M ... -
技术备忘录之五
2009-08-05 22:24 8332009-08-05 symbian使用的设计模式:采用 ... -
技术备忘录之四
2009-08-03 18:48 10142009-08-03 Symbian开发之Carbide ... -
技术备忘录之三
2009-07-30 15:04 7912009-07-29 eclipse的联想功能-- ... -
技术备忘录之二
2009-07-28 23:07 10052009-07-28 structs2标签< ... -
技术备忘录之一
2009-07-28 09:23 9662009-07-27 eclipse及插件安装和配 ...
相关推荐
"文本文件与二进制文件的差异和应用" 文本文件和二进制文件是计算机存储中的两种基本文件类型。它们的区别不在于物理存储,而在于逻辑上的编码方式不同。文本文件是基于字符编码的文件,常见的编码有 ASCII 编码、...
2. **二进制文件**:与文本文件不同,二进制文件可以包含任何类型的数据,包括图像、音频、视频,甚至是程序代码。二进制文件通常以更紧凑的方式存储数据,因为它们不需要额外的字符编码。例如,一个.exe可执行文件...
二进制文件srcfile 转换成文本文件 targetfile,16进制显示。 二进制文件srcfile 转换文本文件 targetfile,16进制显示。 二进制文件转换文本文件 targetfile,16进制显示。 二进制文件转换文本文件,16进制显示...
这个程序会读取名为"binary_file.bin"的二进制文件,将其中的每个字节转换为ASCII字符,并将结果写入"test_file.txt"文本文件。请注意,如果二进制文件包含非ASCII字符,转换可能会导致乱码或不可读的文本。 在实际...
一个很有用的工具,可以将二进制文件转换为文本文件
在计算机编程中,文本文件和二进制文件是两种常见的数据存储形式,它们在读写方式上有着显著的差异。本文将深入探讨这两种文件类型及其在C语言中的处理方法。 首先,文本文件是以人类可读的形式存储数据的,通常...
由于PNG是一种二进制格式,转换过程与处理其他二进制文件(如音频或视频)类似。代码可能包含了读取PNG文件,将其内容存储为二进制数据,然后能够将该二进制数据写回到新的PNG文件中。 在实际应用中,理解这些基本...
然后再将二进制文件还原并存入a3.txt文件。 具体代码如下: #include #include #include #define NSIZE 8 void print_2(int val2); /***********文本文件转二进制**********/ void Text2Bin(const char* sIn,...
文本文件与二进制文件是计算机科学中两个重要的概念,它们在数据存储和处理中扮演着关键角色。本文将深入探讨这两种文件类型的定义、存取方法以及各自的优缺点,帮助读者全面理解它们在实际应用中的差异。 ### 一、...
在计算机领域,文件可以分为两种主要类型:文本文件和二进制文件。了解如何区分这两种文件类型对于数据处理和程序开发至关重要。文本文件通常由可读的字符组成,如ASCII编码,而二进制文件则包含机器可理解的原始位...
总结来说,将二进制文件转换为十六进制是计算机科学中的基本操作,它涉及文件I/O、数据类型转换以及可能的文本文件操作。了解这些知识对理解底层数据处理和软件开发至关重要。"VC 文件转换 bin 二进制 十六进制"这些...
标题中的"hex文件转二进制工具"指的是一个能够将HEX文件转换为二进制文件的软件。这种工具对于那些需要直接将程序烧录到不支持HEX格式的设备,或者希望减小文件大小以提高烧录效率的开发者来说非常有用。 描述中...
在IT领域,文本文件和二进制文件是两种常见的数据存储格式。文本文件通常使用ASCII或Unicode编码,可被人类直接阅读,而二进制文件则包含机器可读的0和1,通常用于高效的数据存储和传输。在这个场景中,我们要讨论...
这是一段小程序,功能是将二进制文件(*.dat)转换成文本文件(或者Excel表格)!
十六进制的文本文件,转为十六进制格式的二进制文件。 从第一个有效字符开始,每2个有效字符(即0~F)输出一个格式化字节,"0x"、"\r\n"、空格等字符会被跳过。
4. **保存二进制数据**:转换后的二进制数据可以以文本文件或二进制文件的形式保存。文本文件通常是以ASCII码或UTF-8编码的二进制表示,而二进制文件则直接保存原始的比特序列。在C++中,可以使用`std::ofstream`...
3. **构建二进制文件结构**:按照二进制STL的文件格式规范,组织这些字节数组,包括文件头信息(通常是“solid”字符串和一些保留字节)和每个三角面片的数据块。 4. **写入二进制文件**:将构建好的二进制数据写入...
"otxt2bintxt2otxt.rar_二进制 文本_文本文件_二进制 文件"这个压缩包涉及了将文本文件与二进制文件之间相互转换的过程。这种转换在计算机科学和编程中具有重要意义,因为不同的系统和应用程序可能需要处理不同格式...
而"stringFile"可能是另一个二进制文件,或者是一个文本文件,具体取决于它的内容。 总的来说,理解和掌握文件与二进制数据之间的转换是编程中的基本技能,尤其对于处理文件I/O和数据存储的开发者来说更为重要。这...
在IT领域,我们经常需要处理各种类型的文件,其中包括二进制文件和文本文件。二进制文件通常包含非打印字符,直接阅读困难,而文本文件则以人类可读的字符编码存储信息。"二进制文件To文本转换器"就是一个解决这种...