c语言中fread函数怎么用?

有一个二进制文件,我想把里面的一个八个字节的数读出来(其实就是1)然后我建立一个int a[];数组,然后调用fread(a,8,1,fp);fp是对应打开文件的指针,怎么就没读进去呢?我把数组改成double 后再读,就能读进去了,可是读的不是1,是一个接近0的小数,我就崩溃了,我的问题是,第二个参数,跟第一个参数有关系吗?八个字节的数到底怎么才能读出来?跪求高手解答!

慕的地10843
浏览 956回答 3
3回答

人到中年有点甜

如果你想把这8个字节当成一个数来读的话可以这样(在VC环境下)__int64 a;fread(&a,sizeof(__int64),1,fp);如果你想分别读出这8个字节的话,可以这样:char a[8];fread(a,sizeof(char),8,fp);希望对你有帮助__int64也可以用来表示一个整数,只不过它能表示的范围比int类型的要大,int类型占4个字节,而这个__int64占8个字节。如果你用的是gcc编译器(像DEV-C等),那应该是long long

心有法竹

fread  功 能: 从一个流中读数据  函数原型: size_t fread(void *buffer,size_t size,size_t count,FILE *stream);   参 数:  1.用于接收数据的地址(指针)(buffer)  2.单个元素的大小(size) :单位是字节而不是位,例如读取一个int型数据就是4个字节  3.元素个数(count)  4.提供数据的文件指针(stream)  返回值:读取的元素的个数因为你读的是二进制文件,你fopen的时候要以fopen(“file”,‘rb’);去读;fread函数中间的size很关键,如果你一次读size个字节(你那里是8个字节),而你的内容没有size那么大,就会读失败。所以建议读的时候1个字节1个字节的读,读n次。fread(a,1,n,fp);返回的是读的元素的次数,即它的个数。而你的二进制文件是按位算的;int型的数组a来保存“1”,说明你的“1”要占4个字节,“1”的二进制是 0000 0000 0000 0001,所以你读的时候fread(a,1,4,fp);只能读4个字节,也就是分4次读。读8个字节的结果就不是"1"了。

烙印99

unsigned char a[8];fread(a,8,1,fp);然后在对a的元素按需求处理。如果声明成double,必须在写文件的时候写入的变量也是double,用double读出来才对。写入字节,用double读出来肯定不对,double是浮点,不是整数,使用8个字节来存储,1个符号位,11位阶数,52位尾数。
打开App,查看更多内容
随时随地看视频慕课网APP