`

Comparision Between Text-files and Binary-files

阅读更多

一、文本文件与二进制文件的定义

 

大家都知道计算机的存储在物理上是二进制的,所以文本文件与二进制文件的区别并不是物理上的,而是逻辑 上的。这两者只是在编码层次上有差异。
简单来说,文本文件是基于字符编码的文件,常见的编码有ASCII编码,UNICODE编码等等。二进制文件是基于值编码的文件,你可以根据具体应用,指 定某个值是什么意思(这样一个过程,可以看作是自定义编码)。
从上面可以看出文本文件基本上是定长编码 的(也有非定长的编码如UTF-8),基于字符嘛,每个字符在具体编码中是固 定的,ASCII码是8个比特的编码,UNICODE一般占16个比特。而二进制文件可看成是变长编码 的,因为是值编 码嘛,多少个比特代表一个值,完全由你决定。大家可能对BMP文件比较熟悉,就拿它举例子吧,其头部是较为固定长度的文件头信息,前2字节用来记录文件为 BMP格式,接下来的8个字节用来记录文件长度,再接下来的4字节用来记录bmp文件头的长度。。。大家可以看出来了吧,其编码是基于值的(不定长 的,2、4、8字节长的值都有),所以BMP是二进制文件。

 

二、文本文件与二进制文件的存取

 

文本工具打开一个文件的过程是怎样的呢?拿记事本来说,它首先读取文件物理上所对应的二进制比特流(前面已经说了,存储都是二进制的),然后按照你所选择 的解码方式来解释这个流,然后将解释结果显示出来。一般来说,你选取的解码方式会是ASCII码形式(ASCII码的一个字符是8个比特),接下来,它8 个比特8个比特地来解释这个文件流。例如对于这么一个文件流"01000001_01000010_01000011_01000100"(下划线 ''_'',是我为了增强可读性,而手动添加的),第一个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系统共享文本文件)。

 

 

分享到:
评论

相关推荐

    A Comparison of SIFT, PCA-SIFT and SURF.ppt

    A Comparison of SIFT, PCA-SIFT and SURF.ppt

    Comparision-Of-IAAS-PAAS-SAAS:小项目2k20

    IAAS-PAAS-SAAS比较运行项目的步骤安装 Django 导航到项目目录打开终端并运行命令“python manage.py runserver” 打开页面“ ”, “ ”, “ ”和“ ”并验证操作对于Docker应用程序: 安装 Docker,然后使用...

    max-min-comparision-block.rar_operation

    在LabVIEW编程环境中,Max_MIN操作是数据处理和分析中常用的一种功能,它涉及到数值比较..."max-min comparision block.vi"文件提供了一个具体的实现案例,用户可以通过打开、学习和修改这个VI来深化对这一概念的理解。

    [MMS_040328]Data Comparision of value in array files.rar

    本资料 "[MMS_040328]Data Comparision of value in array files" 可能是关于如何在AB PLC环境中进行数组内数值的比较和分析的教程或实例。 1. **数组基础知识**:在AB PLC(Allen Bradley PLC,罗克韦尔自动化公司...

    在今天的数字世界,每天有数万亿的银行卡交易发生,检测欺诈行为的发生

    在今天的数字世界,每天有数万亿的银行卡交易发生,检测欺诈行为的发生_是一个严峻挑战。该数据来自一些匿_A-comparision-of-automatic-classifier-for-Bank-card-fraud-forecast

    java实现算法

    Java 实现算法 本文档将对 Java 实现的四种算法进行详细的分析和解释,包括冒泡排序、选择排序、插入排序和 Rank 排序。每种算法都将从思想、实现、复杂度分析三个方面进行详细的介绍。 冒泡排序 ...

    串口调试程序

    串口调试程序

    chabEst01_Para-(1).zip_between_sparse_sparse channel

    THIS IS COMPARISION BETWEEN SPARSE CHANNEL ESTIMATION

    Answer Set Solver Comparision Tool-开源

    标题中的“Answer Set Solver Comparision Tool”是一款专门用于对比不同答案集求解器性能的开源工具。答案集程序(Answer Set Programming, ASP)是一种强大的、声明式的编程范式,广泛应用于逻辑推理、人工智能和...

    Comparision of MODTRAN and FASCODE

    Mazuk和***nch编写的,属于Space Science Applications Laboratory,为Space and Missile Systems Center进行的一项研究,报告是在美国空军物资司令部的批准下发布的,并且对公众开放。这项研究得到了The Aerospace...

    Electronic-price-comparision-

    在电子价格比较这一主题中,我们主要关注的是利用信息技术,特别是HTML(超文本标记语言)来构建一个在线平台,使得用户能够轻松比较不同商家的产品价格。... ...这些元素包括标题(`<h1>`到`<h6>`)、段落(`<p>`)、...

    react-blog:一个简单的react博客和事件

    如果您的博客名称为Writings / comparision-operaror-in-javascript.md,则可以添加如下所示的代码,因为Writings / [slug] .js查找可以传递的slug。 exportPathMap: async function(defaultPathMap, { dev, dir, ...

    Absolute Database for D7

    source code and no source code versions, multi-developers licenses Comparison with other Databases You can see here Comparision with other databases Maximum Capacity SpecificationsObject Maximum ...

    css-reset-comparision:CSS重置比较-不加考虑CSS重置和规范化比较

    css-reset-comparision是一个很棒CSS重置比较。 对于任何网页设计师来说,这都是一个很好的资源。 css-reset-comparision比较所有重置和规范化器。 目录 执照 地位 比较 归一化器 体裁 normalize.css 现代规范...

    Oops-Line-Comparision

    在Java编程语言中,"Oops-Line-Comparision"可能指的是面向对象编程(Object-Oriented Programming,简称OOP)中的一个重要概念,即类与类之间的关系比较。在本项目或教程中,可能通过代码行的对比来分析和理解不同...

    apk增量更新和版本信息查看工具

    在Android应用开发中, APK(Android Package)是用于分发和安装Android应用程序的文件格式。随着应用程序的迭代更新,为了减少用户下载整个新版本apk的流量消耗,开发者常常采用增量更新技术。...

    Suboptimal comparision_fixed_matlab_

    "Suboptimal Comparison of AF and DF Relaying For Fixed Target Error Probability" 这个研究主题聚焦于比较两种常见的中继策略:放大转发(Amplify-and-Forward, AF)和解码转发(Decode-and-Forward, DF),在...

    Lucene-Analyzers---Comparision:测试不同的分析仪

    Lucene-Analyzers---比较测试不同的分析仪使用四个分析器为 AP89 生成 Lucene 索引 KeywordAnalyzer SimpleAnalyzer StopAnalyzer StandardAnalyzer 检查标记化,标记,词干,停用词去除,术语和其他观察

    Computational Comparision of serval CG methods

    标题中的"Computational Comparison of several CG methods"表明这是一个关于比较几种不同的共轭梯度(CG)方法的计算研究。描述中提到的“modified four-term extension of the Dai-Liao conjugate gradient method”...

Global site tag (gtag.js) - Google Analytics