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++实现一个简单的集合类,这篇文章主要介绍了C++简单集合类的实现方法,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • .h和.cpp文件的区别(zt)详细介绍

    .h和.cpp文件的区别(zt)详细介绍

    特别是对源文件和头文件的概念,需要深入对它了解,本文将详细介绍,需要了解的朋友可以参考下
    2012-11-11
  • C++高性能服务器框架之线程模块

    C++高性能服务器框架之线程模块

    该模块基于pthread实现,sylar说,由于c++11中的thread也是由pthread封装实现的,并且没有提供读写互斥量,读写锁,自旋锁等,所以自己封装了pthread,本文主要详细介绍了C++高性能服务器框架中的线程模块,需要的朋友可以参考下
    2023-06-06
  • C语言实现Fibonacci数列递归

    C语言实现Fibonacci数列递归

    这篇文章主要介绍了C语言实现Fibonacci数列递归,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • c与c++之间的相互调用及函数区别示例详解

    c与c++之间的相互调用及函数区别示例详解

    这篇文章主要为大家介绍了c与c++相互调用的使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • C++STL中<functional>的具体使用

    C++STL中<functional>的具体使用

    C++标准库中的<functional>库是一个强大的工具集,它提供了用于处理函数对象、函数绑定、函数包装等功能的设施,极大地增强了代码的灵活性和可复用性,感兴趣的可以了解一下
    2025-11-11
  • C++20新增属性[[no_unique_address]]详解(最新整理)

    C++20新增属性[[no_unique_address]]详解(最新整理)

    [[no_unique_address]]让空类型的类数据成员有机会不再占用额外的内存空间,从而减轻了因为地址规定带来的性能影响,同时还让空基类优化代码得到了简化的机会,本文给大家详细介绍C++20新增属性[[no_unique_address]],感兴趣的朋友一起看看吧
    2025-09-09
  • KMP 算法实例详解

    KMP 算法实例详解

    这篇文章主要介绍了KMP 算法实例详解的相关资料,MP的关键是求出next的值、先预处理出next的值,需要的朋友可以参考下
    2017-07-07
  • 在C++ 中慎用setjmp和longjmp解析

    在C++ 中慎用setjmp和longjmp解析

    setjmp和longjmp是C语言中用于实现非局部跳转的函数,setjmp和longjmp 是 C 语言中一个很强大的函数,这篇文章主要介绍了在C++ 中慎用setjmp和longjmp的相关知识,需要的朋友可以参考下
    2023-06-06
  • 基于Matlab实现数字音频分析处理系统

    基于Matlab实现数字音频分析处理系统

    这篇文章主要为大家介绍了如何利用Matlab制作一个带GUI的数字音频分析与处理系统。文中的示例代码讲解详细,感兴趣的小伙伴可以学习一下
    2022-02-02

最新评论