当前位置: 代码网 > it编程>编程语言>C/C++ > C++中std::ifstream::readsome和std::ifstream::read的区别解析

C++中std::ifstream::readsome和std::ifstream::read的区别解析

2024年08月26日 C/C++ 我要评论
‌std::ifstream::readsome和std::ifstream::read‌的主要区别在于它们处理输入流的方式和可能返回的结果。‌处理方式‌:st

‌std::ifstream::readsome和std::ifstream::read的主要区别在于它们处理输入流的方式和可能返回的结果。

  • 处理方式‌:
  •  
    • std::ifstream::readsome 是一个非阻塞的读取函数,它尝试从输入流中读取一些数据,即使到达文件末尾(eof)也不会立即停止,而是返回已经读取的字节数。这意味着,如果在读取过程中遇到eof,readsome会返回已经读取的数据,而不是等待直到有更多数据可用或直到达到请求的数量。
    • std::ifstream::read 是一个阻塞的读取函数,它会尝试读取指定数量的字节,如果数据不可用,它会等待直到达到请求的数量或者遇到eof。在达到eof时,read会设置eof标志并返回0,表示没有更多数据可以读取。
  •  

    返回值‌:

    • std::ifstream::readsome 返回实际读取的字符数,或者在发生错误时返回一个特殊的值(如流错误状态)。这个函数不会因为到达eof而立即停止,因此可能会返回一个比请求的数量少的值。
    • std::ifstream::read 返回实际读取的字符数,或者在发生错误时设置错误状态并返回一个特殊的值。当到达文件末尾时,它会返回0,表示没有更多数据可以读取。
  •  

    应用场景‌:

    • 当您不确定输入流中是否有足够的数据时,或者当您希望程序在等待数据的同时继续执行其他任务时,std::ifstream::readsome 是一个合适的选择。它允许程序在数据可用时继续处理,而不是完全阻塞等待所有数据都准备好。
    • 当您需要确保读取特定数量的数据,或者当您确信输入流中有足够的数据时,std::ifstream::read 是更合适的选择。它提供了更明确的控制,确保程序在数据不足时不继续执行。

总的来说,选择使用std::ifstream::readsome还是std::ifstream::read取决于您的具体需求:如果您希望程序在数据可用时立即处理,并且不介意可能读取到的数据量少于请求的量,那么std::ifstream::readsome是合适的选择;如果您需要确保读取到确切数量的数据,或者当数据不足时不进行任何操作,那么应该使用std::ifstream::read‌1。

‌std::ifstream::readsome和std::ifstream::read‌的主要区别在于它们处理输入流的方式和可能返回的结果。

  •  

    处理方式‌:

    • std::ifstream::readsome 是一个非阻塞的读取函数,它尝试从输入流中读取一些数据,即使到达文件末尾(eof)也不会立即停止,而是返回已经读取的字节数。这意味着,如果在读取过程中遇到eof,readsome会返回已经读取的数据,而不是等待直到有更多数据可用或直到达到请求的数量。
    • std::ifstream::read 是一个阻塞的读取函数,它会尝试读取指定数量的字节,如果数据不可用,它会等待直到达到请求的数量或者遇到eof。在达到eof时,read会设置eof标志并返回0,表示没有更多数据可以读取。
  •  

    返回值‌:

    • std::ifstream::readsome 返回实际读取的字符数,或者在发生错误时返回一个特殊的值(如流错误状态)。这个函数不会因为到达eof而立即停止,因此可能会返回一个比请求的数量少的值。
    • std::ifstream::read 返回实际读取的字符数,或者在发生错误时设置错误状态并返回一个特殊的值。当到达文件末尾时,它会返回0,表示没有更多数据可以读取。
  •  

    应用场景‌:

    • 当您不确定输入流中是否有足够的数据时,或者当您希望程序在等待数据的同时继续执行其他任务时,std::ifstream::readsome 是一个合适的选择。它允许程序在数据可用时继续处理,而不是完全阻塞等待所有数据都准备好。
    • 当您需要确保读取特定数量的数据,或者当您确信输入流中有足够的数据时,std::ifstream::read 是更合适的选择。它提供了更明确的控制,确保程序在数据不足时不继续执行。

总的来说,选择使用std::ifstream::readsome还是std::ifstream::read取决于您的具体需求:如果您希望程序在数据可用时立即处理,并且不介意可能读取到的数据量少于请求的量,那么std::ifstream::readsome是合适的选择;如果您需要确保读取到确切数量的数据,或者当数据不足时不进行任何操作,那么应该使用std::ifstream::read

下面示例介绍c++中std::ifstream::readsome和std::ifstream::read的区别。

std::ifstream::readsome的原型如下,可以返回实际读到的字节数量,但是不会把eofbit置1,所以不能直接调用eof判断是否到文件尾

streamsize readsome (char* s, streamsize n);

std::ifstream::read原型如下,会置eof, 但没法直接得到实际读取字节数

istream& read (char* s, streamsize n);

如果既需要能获得读取字节数,又需要能判断是否读到文件尾,可有如下两种方法:

1. 使用std::ifstream::readsome

#include <iostream>
#include <fstream>
#include <sstream>
using namespace std;
streamsize read(istream &stream, char *buffer, streamsize count)
{
    // this consistently fails on gcc (linux) 4.8.1 with failbit set on read
    // failure. this apparently never fails on vs2010 and vs2013 (windows 7)
    streamsize reads = stream.rdbuf()->sgetn(buffer, count);
    // this rarely sets failbit on vs2010 and vs2013 (windows 7) on read
    // failure of the previous sgetn()
    stream.rdstate();
    // on gcc (linux) 4.8.1 and vs2010/vs2013 (windows 7) this consistently
    // sets eofbit when stream is eof for the conseguences  of sgetn(). it
    // should also throw if exceptions are set, or return on the contrary,
    // and previous rdstate() restored a failbit on windows. on windows most
    // of the times it sets eofbit even on real read failure
    stream.peek();
    return reads;
}
int main(int argc, char *argv[])
{
    ifstream instream("filepath", ios_base::in | ios_base::binary);
    while (!instream.eof())
    {
        char buffer[0x4000];
        size_t read = read(instream, buffer, sizeof(buffer));
        // do something with buffer 
    }
}

2. 使用std::ifstream::read后,使用gcount()获得上一次读取的字节数

ifstream ifs("a.txt");
char buf[1024];
ifs.read(buf, 1024);
size_t extracted = ifs.gcount();
// or
ifstream ifs("a.txt");
char buf[1024];
size_t extracted = ifs.read(buf, 1024).gcount();

ref:

https://stackoverflow.com/questions/9191876/when-does-ifstreamreadsome-set-eofbit

https://stackoverflow.com/questions/11720880/ifstreamread-doesnt-tell-how-many-bytes-it-really-reads

到此这篇关于std::ifstream::readsome和std::ifstream::read的区别的文章就介绍到这了,更多相关std::ifstream::readsome和std::ifstream::read区别内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com