博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
fread函数返回值
阅读量:5949 次
发布时间:2019-06-19

本文共 1069 字,大约阅读时间需要 3 分钟。

hot3.png

fread函数原型:

size_t fread ( void *buffer, size_t size, size_t count, FILE *stream) ;

size和count的含义:每次读count个块,每块为size字节

fread的返回值含义为:读到的块数,假定现在返回值为num(size太具有歧义,会让人以为是读到的字节数)

num值的判断:

1.num == count,读操作成功,返回count*size个字节;

2.num == 0,此时fread并不一定是读错了或到文件末尾了,fread函数返回值并没有判断这两种情况,以上两种情况只能用函数ferror和feof判断(返回值非零为正常)。

   当num为0时,也有可能只是读到的块数为0,前面说了不一定是文件末尾,那为什么会返回0呢?

    num = fread ( buf, 1024, 1, fp),看一下这个例子,假如你的文件大小不足1024字节,或是循环读文件,最后一次循环剩余的字节小于1024字节,这个时候fread就会返回0值,并且buf中没有数据,这就导致文件根本没有读过去或是没读够。

解决这个问题的方法:

1.最简单,也就粗暴的方法,就是将size置为1, fread ( buf, 1, 1024, fp),一次读1字节,怎么样都不会错,这个方法的缺点就在于效率低下,并不是fread函数使用的初衷,以块读写是为了提高效率的,所以这种方法只能用于没有办法的时候。

2.在读文件之前,先使用stat函数,获取文件的大小,这样读取到末尾的时候直接写具体的大小就好了,大致如下:

  filesize = stat(file,...);

  n = filesize/size;

  remain = filesize%size;

  while(n){ fread(..,size,........);    n--;    }

  fread(..,remain,............);

此方法的缺点就是stat函数是linux系统函数,windows系统下无法使用,暂时也没找到替代函数.......(linux系统还可以直接用read函数.....windows简直.............第一种方法就是在没找到更好的方法之前,在windows下用的,没有办法的办法)

 

PS:如果大神们能看见我的拙见,有更好的在windows下的解决方法,一定要告诉我[含泪期待脸]

 

 

 

 

 

转载于:https://my.oschina.net/u/2404244/blog/715461

你可能感兴趣的文章
专访刘刚:360手机卫士的性能监控与优化
查看>>
FB正在大规模重构React Native,预计今年发布
查看>>
从0到1:腾讯Yoo视频底层页推荐系统实践
查看>>
推荐10个CI/CD工具,用于云平台集成交付
查看>>
云平台宕机引发的系列思考,企业如何自救?
查看>>
Java EE跟JCP说再见
查看>>
整洁代码之道——重构
查看>>
Oracle加入CNCF,发布Kubernetes on Oracle Linux以及Terraform Kubernetes Cloud Installer
查看>>
Scrum指南更新:Ken Schwaber、Jeff Sutherland访谈
查看>>
在瑞士最大银行驱动创新
查看>>
CRI Shimv2:一种 Kubernetes 集成容器运行时的新思路
查看>>
机器人操作系统来到Windows
查看>>
通过规模化Scrum创造最新技术的打印机
查看>>
时序数据库DolphinDB和TimescaleDB 性能对比测试报告
查看>>
准备好了?测试人员迟早会被要求测试包含区块链技术的解决方案
查看>>
用户故事 | 刷算法面试题的4种思考方式
查看>>
Visual Studio 2017 15.9 Previews扩展C++调试功能
查看>>
宜人贷CTO段念:透明与面向目标是管理理念的核心
查看>>
理解HTTPS
查看>>
linux环境下apache配置虚拟站点
查看>>