为什么istreambuf_iterator推进不起作用

Why doesn't the istreambuf_iterator advance work

本文关键字:不起作用 iterator istreambuf 为什么      更新时间:2023-10-16

我正在阅读用istream_iterators构建一个向量,这是关于将一个完整的文件内容读取到一个字符向量中。而我希望将文件的一部分加载到字符向量中。

#include <iostream>
#include <fstream>
#include <iterator>
#include <vector>
#include <algorithm>
using namespace std;
int main(int argc, char *argv[])
{
    ifstream ifs(argv[1], ios::binary);
    istreambuf_iterator<char> beginItr(ifs);
    istreambuf_iterator<char> endItr(beginItr);
    advance(endItr, 4);
    vector<char> data(beginItr, endItr);
    for_each(data.cbegin(), data.cend(), [](char ch)
    {
            cout << ch << endl;
    });
}

这不起作用,因为提前是不起作用的,而前面提到的问题的公认答案是有效的。为什么istreambuf_iterator的前期工作不到位?

还有

  endItr++;
  endItr++;
  endItr++;
  endItr++;
  cout << distance(beginItr, endItr) << endl;

返回0。请有人解释一下发生了什么事!

为什么在istreambuf_titerator上不进行高级工作?

它有效。它推进迭代器。问题是istreambuf_iterator输入迭代器,而不是前向迭代器,这意味着它是一个单程迭代器:一旦你推进它,你就再也无法访问以前的状态。要做你想做的事情,你可以简单地使用一个老式的for循环,它的计数为4。

istreambuf_iteratorbasic_streambuf读取连续字节。它不支持定位(basic_istream::seekgbasic_istream::tellg)。

这是因为它是一个单程输入迭代器,而不是前向迭代器或随机访问迭代器;它被设计为能够处理不支持定位的流(例如管道或TCP套接字)。

您可能会发现file/ifstream上的双向迭代器中的一些解决方案非常有用。

如果其他人偶然发现了这个问题,并且想要一些替代的简单代码,你可以尝试这样的方法:

        std::vector<char> buffer{4};
        std::ifstream source{argv[1], std::ios_base::binary};
        source.read(buffer.data(), buffer.size());