C++中std::ifstream::readsome和std::ifstream::read的区别解析
作者:photon_wa
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区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!