C++ - Google 基准停止计时函数

C++ - Google benchmark stop timing function

我正在尝试排除将字符串转换为函数中的对象。这是涉及的函数:

std::vector<std::pair<value_type, size_t>> read_file(const std::string path, benchmark::State& state) {
  
  std::string kmer;
  std::vector<std::pair<value_type, size_t>> data;
  
  std::ifstream file(path);
  while (std::getline(file, kmer)) {
    state.PauseTiming();
    kmer_t tmp(kmer);
    state.ResumeTiming();
    data.push_back(std::make_pair(tmp.value, tmp.index));
  }

  return data;
}

作用域是读取一个文件,逐行转换成一个对象。结果对象被插入到向量对中。 我在我的项目中包含 google benchmark 库来计算使用了多少时间和内存。我想从总数中排除转换。我像 documentation 说的那样实现了这个功能,但结果时间比没有定时器管理的正常计算要长得多。

我也发现了这个旧的但相关的 opened issue 但我无法解决我的问题。 我该如何解决这个问题或有任何解决方法?

您在这里无能为力,这是预料之中的。启动和停止计时器需要与 OS 进行某种形式的同步,在您的情况下,这种开销似乎比创建临时对象要高得多。

不过,这应该不是问题。如果您尝试比较几种填充向量的方法并排除在所有方法中创建对象,那么停止和重新启动计时器的开销对于所有这些不同的方法都是相同的,因此如果其中一种方法比另一个更快它也会随着增加的定时器管理开销而更快,只是相对差异会更小。

我什至会争辩说,在你测量文件的整个解析而不是微基准测试的情况下,例如push_back vs emplace_back 最好将对象创建包含在测量中,以便更准确地了解性能差异的显着程度,例如将此版本与在迭代之间重用 kmer_t 对象的版本进行比较(因此可能重用已为数据成员分配的内存)。