谷歌基准测试:断言`has_range_x_'失败了

时间:2016-08-02 16:30:59

标签: c++ gcc benchmarking microbenchmark google-benchmark

在一个项目中,我开始使用https://github.com/google/benchmark.git标记v1.0.0中的google / benchmark。

我运行非常简单的测试

#include <benchmark/benchmark.h>
#include <cstring>

static void BM_memcpy(benchmark::State& state) {
  char* src = new char[state.range_x()]; char* dst = new char[state.range_x()];
  memset(src, 'x', state.range_x());
  while (state.KeepRunning())
    memcpy(dst, src, state.range_x());
  state.SetBytesProcessed(int64_t(state.iterations()) *
                          int64_t(state.range_x()));
  delete[] src;
  delete[] dst;
}
BENCHMARK(BM_memcpy)->Arg(8)->Arg(64)->Arg(512)->Arg(1<<10)->Arg(8<<10);

// Register the function as a benchmark
BENCHMARK(BM_memcpy);

BENCHMARK_MAIN();

但我收到了错误

./bench/simple-benchmark 
Run on (8 X 4000 MHz CPU s)
2016-08-02 18:22:30
Benchmark               Time           CPU Iterations
-----------------------------------------------------
BM_memcpy/8             9 ns          9 ns   79545455       877MB/s
BM_memcpy/64            9 ns          9 ns   56451613   6.67615GB/s
BM_memcpy/512          21 ns         21 ns   33018868   23.0185GB/s
BM_memcpy/1024         30 ns         29 ns   23648649   32.4039GB/s
BM_memcpy/8k          516 ns        514 ns    1346154   14.8415GB/s
simple-idl-benchmark: /usr/local/include/benchmark/benchmark_api.h:417: int benchmark::State::range_x() const: Assertion `has_range_x_' failed.

我尝试了大师级和旧版本的标签,但我总是得到这个断言。我在debian / test上使用gcc 5.4.0来测试基准库和简单基准可执行文件。

对我来说,它似乎无法检测到参数列表的结尾并且它断言。但有什么不对?怎么预防呢?

1 个答案:

答案 0 :(得分:1)

您注册了两次基准(BENCHMARK的来电),但第二次没有提供Arg。也就是说,你在不设置范围的情况下调用它,就像断言断言一样。