1、文本文件与二进制文件的定义
你们都知道计算机的存储在物理上是二进制的,因此文本文件与二进制文件的区别并非物理上的,而是逻辑上的。这二者只是在编码层次上有差别。简单来讲,文本文件是基于字符编码的文件,常见的编码有ASCII编码,UNICODE编码等等。二进制文件是基于值编码的文件,你能够根据具体应用,指定某个值是什么意思(这样一个过程,能够看做是自定义编码。
从上面能够看出文本文件基本上是定长编码的(也有非定长的编码如UTF-8)。而二进制文件可当作是变长编码的,由于是值编码嘛,多少个比特表明一个值,彻底由你决定。你们可能对BMP文件比较熟悉,就拿它举例子吧,其头部是较为固定长度的文件头信息,前2字节用来记录文件为BMP格式,接下来的8个字节用来记录文件长度,再接下来的4字节用来记录bmp文件头的长度。
2、文本文件与二进制文件的存取
文本工具打开一个文件的过程是怎样的呢?拿记事原本说,它首先读取文件物理上所对应的二进制比特流,而后按照你所选择的解码方式来解释这个流,而后将解释结果显示出来。通常来讲,你选取的解码方式会是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"这四个控制符。
文本文件的存储与其读取基本上是个逆过程。而二进制文件的存取显然与文本文件的存取差很少,只是编/解码方式不一样而已,也再也不叙述。
3、文本文件与二进制文件的优缺点
由于文本文件与二进制文件的区别仅仅是编码上不一样,因此他们的优缺点就是编码的优缺点,这个找本编码的书来看看就比较清楚了。通常认为,文本文件编码基于字符定长,译码容易些;二进制文件编码是变长的,因此它灵活,存储利用率要高些,译码难一些(不一样的二进制文件格式,有不一样的译码方式)。关于空间利用率,想一想看,二进制文件甚至能够用一个比特来表明一个意思(位操做),而文本文件任何一个意思至少是一个字符。
在windows下,文本文件不必定是一ASCII来存贮的,由于ASCII码只能表示128的标识,你打开一个txt文档,而后另存为,有个选项是编码,能够选择存贮格式,通常来讲UTF-8编码格式兼容性要好一些.而二进制用的计算机原始语言,不存贮兼容性. 不少书上还认为,文本文件的可读性要好些,存储要花费转换时间(读写要编译码),而二进制文件可读性差,存储不存在转换时间(读写不要编解码,直接写值).这里的可读性是从软件使用者角度来讲的,由于咱们用通用的记事本工具就几乎能够浏览全部文本文件,因此说文本文件可读性好;而读写一个具体的二进制文件须要一个具体的文件解码器,因此说二进制文件可读性差,好比读BMP文件,必须用读图软件。
而这里的存储转换时间应该是从编程的角度来讲的,由于有些操做系统如windows须要对回车换行符进行转换(将''\n'',换成''\r\n'',因此文件读写时,操做系统须要一个一个字符的检查当前字符是否是''\n''或''\r\n'').这个在存储转换在Linux操做系统中并不须要,固然,当在两个不一样的操做系统上共享文件时,这种存储转换又可能出来。
4、二进制文件是计算机可以直接识别、运行的,而不适合与人来阅读。文本文件适合于人阅读,大部分文本文件不是可执行文件,可是像一些脚本语言编写的文本文件,例如Windows的批处理文件、Linux的shell脚本是可以直接执行的,不过还须要解释器。
补充:咱们对文本进行操做的话,读取的数据都是字符串形式的,将数据写入到文本中,须要事先将数据的类型转变成字符串类型的。