你真的会用read()读【普通文件】吗?

原型如下:

#include <unistd.h>

ssize_t read (int __fd, void *__buf, size_t __nbytes);    

如果是读【普通文件】,可能的返回是:

  • 0读到了文件尾。
  • <= nbytes,可能是文件没有这么多字节了。
  • -1,出错。

注意,-1出错的时候,errno会返回错误码。

其中有一个errno需要引起我们注意,就是EINTR。手册里面是这么解释的:当任何数据没有读到的时候,如果调用被中断,返回-1且errno设置为EINTR。言外之意是如果读到了,会返回读了多少,这种有数据的不会返回-1。

看起来这个异常情况需要处理,避免真的不凑巧刚调用,被信号中断了,那其不是被误认为出错了吗?可是真的是这种情况要处理吗?

还真有人说需要处理(见https://blog.csdn.net/feit2417/article/details/82498653),他文章里面是这么说的:


分享一个工业级代码,read读文件数据。

读的过程中,调用被信号中断,于是返回一个EINTR错误,read读取失败。

由于没有读到数据而被意外中断,所以需要从新读数据。while (ret < 0 && EINTR == errno);

实例代码:

bzero(buf, sizeof
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值