-
人到中年有点甜
如果你想把这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位尾数。