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

 更新时间:2024年08月26日 10:17:32   作者:photon_wa  
‌std::ifstream::readsome和std::ifstream::read‌的主要区别在于它们处理输入流的方式和可能返回的结果,下面给大家介绍C++中std::ifstream::readsome和std::ifstream::read的区别解析,感兴趣的朋友跟随小编一起看看吧

‌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区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C语言实现五子棋小游戏

    C语言实现五子棋小游戏

    五子棋游戏是一款很经典的智力游戏,只有学过编程语言的人,把五子棋的编程原理弄懂了,就能用自己熟悉的语言实现出来,在这里给大家分享,c语言五子棋源码,仅供大家参考借鉴。
    2016-03-03
  • C语言函数的参数使用指针

    C语言函数的参数使用指针

    这篇文章主要介绍了C语言函数的参数使用指针,本文讲述了指针在作为函数参数时候的使用方法,解析值传递和值引用的区别案例,希望对你有所帮助
    2021-06-06
  • 基于Matlab实现野狗优化算法的示例代码

    基于Matlab实现野狗优化算法的示例代码

    野狗优化算法(Dingo Optimization Algorithm, DOA)模仿澳大利亚野狗的社交行为。DOA算法的灵感来源于野狗的狩猎策略,即迫害攻击、分组策略和食腐行为。本文将通过Matlab实现这一算法,感兴趣的可以了解一下
    2022-04-04
  • C语言实现数独辅助器(附源码)

    C语言实现数独辅助器(附源码)

    数独是源自瑞士的一种数学游戏。是一种运用纸、笔进行演算的逻辑游戏。本文将利用C语言制作一个数独辅助器,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-01-01
  • C++中auto关键字的使用

    C++中auto关键字的使用

    本文主要介绍了C++中auto关键字的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • C++中正则表达式的使用方法详解

    C++中正则表达式的使用方法详解

    几乎所有的编程语言都支持正则表达式。 C++从C++11开始直接支持正则表达式。除了编程语言之外,大多数文本处理程序都使用正则表达式。本文将探讨正则表达式的一般细节以及C++编程方面的细节,感兴趣的可以学习一下
    2022-05-05
  • C语言数据结构之队列算法详解

    C语言数据结构之队列算法详解

    这篇文章介绍了C语言数据结构之队列的算法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-12-12
  • C语言形参与实参使用的差别讲解

    C语言形参与实参使用的差别讲解

    形参出现在函数定义中,在整个函数体内都可以使用, 离开该函数则不能使用。实参出现在主调函数中,进入被调函数后,实参变量也不能使用,形参和实参的功能是作数据传送。发生函数调用时, 主调函数把实参的值传送给被调函数的形参从而实现主调函数向被调函数的数据传送
    2023-02-02
  • Qt实现绘制多个设备的流量曲线图详解

    Qt实现绘制多个设备的流量曲线图详解

    这篇文章主要为大家详细介绍了如何使用Qt开发绘制多个设备的流量曲线图,文中的示例代码讲解详细,对我们学习Qt有一定的帮助,需要的可以参考一下
    2023-01-01
  • C++回溯法实例分析

    C++回溯法实例分析

    这篇文章主要介绍了C++回溯法,实例讲述了回溯法的原理与实现方法,最后给出了回溯法解决八皇后的实例,需要的朋友可以参考下
    2014-09-09

最新评论