`
buluzhai
  • 浏览: 110153 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

文本流与二进制流的区别

阅读更多
一、文本文件与二进制文件的定义
大家都知道计算机的存储在物理上是二进制的,所以文本文件与二进制文件的区别并不是物理上的,而是逻辑上的。这两者只是在编码层次上有差异。
简单来说,文本文件是基于字符编码的文件,常见的编码有ASCII编码,UNICODE编码等等。二进制文件是基于值编码的文件,你可以根据具体应用,指定某个值是什么意思(这样一个过程,可以看作是自定义编码)。
从上面可以看出文本文件基本上是定长编码的(也有非定长的编码如UTF-8),基于字符嘛,每个字符在具体编码中是固定的,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系统共享文本文件)。
分享到:
评论

相关推荐

    汉字转化成二进制的方法

    在信息技术领域,汉字与计算机的交互往往需要将其转化为计算机能够理解和处理的二进制形式。本主题主要探讨的是如何将汉字转化为二进制,这是一个基础且关键的过程,对于编程和数据存储至关重要。 汉字转化为二进制...

    文件下载,二进制流转换成文件 解决中文名乱码的问题

    而在本例中,代码片段展示了如何使用二进制流来实现文件下载功能。 ### 代码解读 #### 方法定义 ```csharp public void CreateFile(byte[] buffer, string fileName) ``` - **`byte[] buffer`**: 这是一个二进制...

    二进制编辑器汉化版

    5. **加密与解密**:在处理加密文件或流时,二进制编辑器可以用来查看加密后的原始数据,帮助理解加密算法并可能实现解密。 6. **调试**:在某些情况下,当传统的调试器无法使用时,二进制编辑器可以作为辅助工具,...

    Python3.7.2中文文档-标准库-Python二进制数据服务

    2. **binascii模块**: 这个模块提供了许多二进制与ASCII之间的转换函数,例如将十六进制字符串转换为字节,或将字节转换为Base64编码。这对于在不同的数据格式之间进行转换非常有用。 3. **struct模块**: 结构化...

    asp.net从数据库中读二进制生成word文件并转换为MHT文件

    本示例介绍如何在ASP.NET环境中从数据库中读取二进制数据生成Word文件,并进一步将其转换为MHT(单个文件网页)格式。MHT格式是一种可以将所有资源(如图片、样式表等)内嵌到单一文件中的Web页面保存格式,方便离线...

    NativeXML(修正读写二进制错误及读写Collection错误)

    这些错误可能源于数据编码、解码问题,或者是处理二进制流时的边界条件不正确。修复这部分错误意味着现在NativeXML能够更准确地处理二进制数据,确保图片和其他二进制对象在XML文档中被正确地序列化和反序列化,同时...

    二进制打开工具

    二进制文件是计算机系统中的一种数据存储形式,它们不以人类可读的文本格式存在,而是由0和1组成的数字序列。对于开发者和IT专业人员来说,理解并能够查看这些二进制文件的内容至关重要,尤其是在进行软件逆向工程、...

    微软复合文档文件格式 二进制分析

    ### 微软复合文档文件格式 二进制分析 #### 1. 引言 微软复合文档文件格式(Microsoft Compound Document File Format)是一种用于存储多种数据类型的数据结构,广泛应用于Microsoft Office文档中,如DOC、XLS等。...

    Openresty二进制版本(openresty-1.19.9.1-win32.zip)

    `openresty-1.19.9.1-win32.zip`是针对Windows 32位系统的OpenResty二进制版本,包含了运行OpenResty所需的所有组件。 1. **OpenResty核心组件**: - **Nginx**:OpenResty基于Nginx,一个高效的反向代理服务器和...

    【nexus二进制库Jar包批量上传脚本工具】

    标题中的“nexus二进制库Jar包批量上传脚本工具”是指用于自动化上传Java的JAR文件到Nexus仓库的脚本程序。Nexus是一个流行的仓库管理器,广泛应用于软件开发环境中,尤其是Java生态系统,它能管理和分发各种类型的...

    C#存取二进制图片[文].pdf

    本例中,我们关注的是如何使用C#处理SQL Server数据库中的二进制图像数据。以下是关键知识点: 1. **二进制数据存储**: - 在SQL Server中,用于存储大对象(如图像)的数据类型是`varbinary(max)`。这个字段可以...

    易语言fasm创建供易语言使用的二进制代码

    8. **调试与测试**:在开发过程中,学会使用调试工具,如OllyDbg或Windbg,来调试FASM生成的二进制代码,确保其在易语言中的正确运行。 9. **跨平台能力**:虽然易语言本身可能有平台限制,但FASM生成的二进制代码...

    易语言简单的二进制加密源码-易语言

    本话题主要围绕"易语言简单的二进制加密源码"展开,旨在深入理解二进制数据的加密原理及其实现方法。 二进制数据是计算机处理的基本形式,包括图片、音频、视频等所有非文本类型的数据。加密是对这些数据进行保护的...

    易语言十六进制编辑器源码

    3. **数据解析与显示**:在界面上以十六进制形式展示文件内容,需要将二进制数据转换为十六进制字符串。此外,可能还需要实现不同颜色高亮显示特定字节或字节序列的功能。 4. **编辑功能实现**:包括插入、删除、...

    16进制编辑器.zip

    3. **编辑与修改**:除了查看,16进制编辑器还允许用户直接修改文件的二进制内容,从而实现数据的精细操控。 4. **比较文件**:通过比较两个文件的二进制差异,16进制编辑器可以用于识别文件之间的微小差异,这对于...

    Openresty二进制版本(openresty-1.19.9.1-win64.zip)

    标题提到的"openresty-1.19.9.1-win64.zip"是OpenResty的一个二进制发行版,适用于Windows 64位操作系统。 OpenResty的核心组件是Nginx,一个非常高效的反向代理服务器和负载均衡器。Nginx以其事件驱动、非阻塞I/O...

    fasm创建供易语言使用的二进制代码源码-易语言

    本教程将详细介绍如何使用fasm来创建二进制代码,以便供易语言(E语言)使用。 易语言,是中国自主研发的一种简单易学的编程语言,它以“中文编程”为理念,致力于降低编程学习的门槛。易语言提供了丰富的库函数和...

    易语言源码易语言JS十六进制分割转换源码.rar

    4. 十六进制转二进制数据流:对于存储在网络传输或文件中的二进制数据,可能会以十六进制字符串的形式出现,这种情况下需要将这些字符串还原成原始的二进制数据。 易语言提供了丰富的内置函数和模块,可以方便地...

    MATLAB操作txt总结.doc

    文本流是解释性的,最长可达 255 个字符,其中回车/换行将被转换为换行符“\n”。二进制流是非解释性的,一次处理一个字符,并且不转换字符。 三、MATLAB 中的文本文件读取技巧 在 MATLAB 中,读取文本文件可以...

    mux-demux-stream:二进制文本流的复用器和解复用器

    Mux Demux流二进制/文本流的多路复用器和多路分解器,灵感来自的《 》一书。 使用单个多路复用器或多路分解器多路复用和多路分解多达八个二进制/文本流。 每个数据块前面都带有五个字节的标头,包括通道ID和有效载荷...

Global site tag (gtag.js) - Google Analytics