gpt4 book ai didi

c++ - 为什么 ifstream::read 比使用迭代器快得多?

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:43:16 24 4
gpt4 key购买 nike

事实上,有很多方法可以将文件读入字符串。两个常见的是使用 ifstream::read 直接读取字符串,以及使用 steambuf_iterators 和 std::copy_n:

使用 ifstream::read:

std::ifstream in {"./filename.txt"};
std::string contents;
in.seekg(0, in.end);
contents.resize(in.tellg());
in.seekg(0, in.beg);
in.read(&contents[0], contents.size());

使用 std::copy_n:

std::ifstream in {"./filename.txt"};
std::string contents;
in.seekg(0, in.end);
contents.resize(in.tellg());
in.seekg(0, in.beg);
std::copy_n(std::streambuf_iterator<char>(in),
contents.size(),
contents.begin();

许多基准测试表明第一种方法比第二种方法快得多(在我使用 g++-4.9 的机器上,使用 -O2 和 -O3 标志大约快 10 倍),我想知道可能是什么原因这种性能上的差异。

最佳答案

read 是单个 iostream 设置(每个 iostream 操作的一部分)和对操作系统的单个调用,直接读入您提供的缓冲区。

迭代器通过使用 operator>> 重复提取单个 char 来工作。由于缓冲区大小,这可能意味着更多的操作系统调用,但更重要的是,它还意味着重复设置和拆除 iostream 哨兵,这可能意味着互斥锁,通常意味着一堆其他东西。此外,operator>> 是格式化操作,而 read 是未格式化的,这是每个操作的额外设置开销。

编辑:疲劳的眼睛看到了 istream_iterator 而不是 istreambuf_iterator。当然 istreambuf_iterator 不做格式化输入。它在 streambuf 上调用 sbumpc 或类似的东西。仍然有很多调用,并且使用了可能比整个文件还小的缓冲区。

关于c++ - 为什么 ifstream::read 比使用迭代器快得多?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29758698/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com