3 回答
![?](http://img1.sycdn.imooc.com/533e4cde000148e602000200-100-100.jpg)
TA贡献1895条经验 获得超7个赞
如果你想把这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
![?](http://img1.sycdn.imooc.com/533e4c7b00013f3c02400205-100-100.jpg)
TA贡献1866条经验 获得超5个赞
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"了。
![?](http://img1.sycdn.imooc.com/5333a0780001a6e702200220-100-100.jpg)
TA贡献1829条经验 获得超13个赞
unsigned char a[8];
fread(a,8,1,fp);
然后在对a的元素按需求处理。
如果声明成double,必须在写文件的时候写入的变量也是double,用double读出来才对。
写入字节,用double读出来肯定不对,double是浮点,不是整数,使用8个字节来存储,1个符号位,11位阶数,52位尾数。
- 3 回答
- 0 关注
- 1018 浏览
添加回答
举报