C语言二进制流写入文件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言二进制流写入文件相关的知识,希望对你有一定的参考价值。

C语言中如何将二进制流写入文件?
这里的二进制流我指的是0101这样的二进制,也就是可以具体到可以往文件里写入几个位的。如往文件里写入一个char类型是往里写了一个字节,也就是8位。如今我想往里写具体几个位

像哈夫曼压缩中,一个字符是一字节也就是8位,进行哈夫曼编码后该字符由一串数字替代,如010。那我在存储的时候当然不能用三个int来存储了,三个int就96位了比原来字符花的空间还多。所以存的时候是用三位来存的吧?那这三比特的编码要如何写入文件呢?还是有其他方法?

最好是C的方法,C++的凑合,其他语言的就算了。请各位C高手赐教啊!

我提个思路。字节是计算机操作的实际最基本单位,任何地址只能精确到字节而无法精确到位的。
所以LZ一定要将位整合到以字节为单位才能进行其他操作。可以这么做,将二进制流按照每8位一个单位装成一个字节,并明确好字节之间的顺序,字节内高低位的顺序,最后末尾不足的要塞一些没意义的但LZ要知道的位凑足成字节。这里面当然必须反复用到位运算。
通常的做法是字节之间的顺序按照自然字节地址由小到大顺序,字节内低位在前。比如对于已经整合成字节的字节流a[N],查看第 i 个位(从0起)的算法是 a[i/8] & (1<<(i%8))。
不同的位序约定会稍有不同位操作
参考技术A 除非用机器语言编程,一般表示三位二进制,都很按串操作的,但是貌似不是3bits而是3Bytes 参考技术B 你的使用位操作和字节对齐,假设你要写第0位,第1位,第2位,你可以:
unsigned char b;
b=0x07;
fwrite(&b,1,1,fp);

如果你要写第4位为1,需要把所在位置那个字节读出来,
fread(&b,1,1,fp);
b|=1<<3;
fwrite(&b,1,1,fp);

如果是连续写,你可以拼满一个字节再写进去,剩余的位构造下一个字节,如果数据全完,当前字节还不足8位,可以用0填充剩余位。

你找找 位操作 的知识看下,就明白了。本回答被提问者和网友采纳
参考技术C 你的使用位操作和字节对齐,假设你要写第0位,第1位,第2位,你可以:
unsigned
char
b;
b=0x07;
fwrite(&b,1,1,fp);
如果你要写第4位为1,需要把所在位置那个字节读出来,
fread(&b,1,1,fp);
b|=1<<3;
fwrite(&b,1,1,fp);
如果是连续写,你可以拼满一个字节再写进去,剩余的位构造下一个字节,如果数据全完,当前字节还不足8位,可以用0填充剩余位。
你找找
位操作
的知识看下,就明白了。
参考技术D 你要是要求不高,
A. 就是先开一个数组,
B.算好数值以后
C.凑整成为字节
D.写入
C++的可以用bitset,专门干这个的。
不过,你说的压缩算法,汇编会快得太多,也就是作业会用我说的方法。

C语言中的文本流与二进制流的区别

  近期看到了文本流和二进制流的区别,书上讲的比较含糊,理解不透彻,于是细细琢磨了下,把心得跟大家分享一下:

一、首先回答,什么是文件,流

  一个文件通常就是磁盘上的一段命名的存储区。比如 stdio.h 就是一个包含一些有用信息的文件的名称。

  C将文件看成是连续的字节序列,其中每一个字节都可以单独地读取。这与 UNIX 环境(C的发源地)中的文件结构是一致的。因为其他环境中的文件模型可能会有所不同,所以 ANSI C 提供了文件的两种视图:文本视图和二进制视图。

  C将数据的输入输出看作是数据的流入和流出,不管是磁盘文件或者是物理设备都可看作一种流的源和目的,视他们为同一种东西,而不管其具体的物理结构,即对他们的操作,就是数据的流入和流出。这种把数据的输入输出操作对象,抽象化为一 种流,而不管它的具体结构的方法很有利于编程,而涉及流的输出操作函数可用于各种对象,与其具体的实体无关,即具有通用性。
  

二、文本视图和二进制视图区别 

  二进制视图中每个字节都可以为程序所访问。

  在文本视图中,程序看到的内容和文件的内容有可能不同(非 UNIX 环境)。举例,DOS下有个文件 test.txt,内容为

hello\\r\\n
world\\r\\n
^Z

当以二进制模式打开 test.txt 时,C程序看到的内容跟原来一样(如下),此时,没有任何映射发生。

hello\\r\\n
world\\r\\n
^Z

当以文本模式打开 test.txt 时,C程序看到的是如下内容:(注意行尾和文件结束符)

hello\\n
world\\n

也就是说使用文本视图读取文件时,将把行尾的本地环境表示法映射为 C 视图;在输出的时候,也会将 C 视图中的行尾表示映射为本地环境表示法。这样,C 通过文本视图巧妙的将不同环境(DOS,MAC)下的文件转换为相同的表示(UNIX下的表示法)。

而二进制视图则与原文件没有丝毫变化!有点理解了吧?

 

三、文本文件与二进制文件

  文本文件是基于字符编码的文件,基本是定长的,常见的编码有ASCII编码,UNICODE编码等等。二进制文件是基于值编码的文件,变长编码,你可以根据具体应用,指定某个值是什么意思(这样一个过程,可以看作是自定义编码)。
    文本工具打开一个文件的过程是怎样的呢?拿记事本来说,它首先读取文件物理上所对应的二进制比特流,然后按照你所选择的解码方式来解释这个流,最后将解释结果显示出来。当用记事本打开二进制文件时,由于按既定的字符编码工作(如ASCII码),所以出现乱码也是很必然的一件事情了。

  文本文件编码基于字符定长,译码容易些;二进制文件编码是变长的,所以它灵活,存储利用率要高些,译码难一些(不同的二进制文件格式,有不同的译码方式)。 文本文件的可读性要好些,存储要花费转换时间(读写要编译码),而二进制文件可读性差(需要具体的文件解码器),存储不存在转换时间(读写不要编解码,直接写值)。

  你懂了吗?

Stay hungryStay foolish

以上是关于C语言二进制流写入文件的主要内容,如果未能解决你的问题,请参考以下文章

c# 将字符串以二进制形式写入文件

紧急求助!!!JAVA语言下如何将二进制数字写入文件然后读出来

C语言将数据写入文件,读取出现二次读取

c#二进制文件的写入和读取

c语言如何读写二进制

C语言如何写入文本文件