mirror of
https://github.com/google/benchmark.git
synced 2024-12-28 05:20:14 +08:00
7d0d9061d8
* Support -Wsuggest-override google/benchmark is C++11 compatible but doesn't use the `override` keyword. Projects using google/benchmark with enabled `-Wsuggest-override` and `-Werror` will fail to compile. * Add -Wsuggest-override cxx flag * Revert unrelated formatting * Revert unrelated formatting, take 2 * Revert unrelated formatting, take 3 * Disable -Wsuggest-override when compiling tests, gtest does not handle it yet Co-authored-by: Dominic Hamon <dominichamon@users.noreply.github.com>
52 lines
1.2 KiB
C++
52 lines
1.2 KiB
C++
|
|
#include "benchmark/benchmark.h"
|
|
|
|
#include <cassert>
|
|
#include <memory>
|
|
|
|
#define FIXTURE_BECHMARK_NAME MyFixture
|
|
|
|
class FIXTURE_BECHMARK_NAME : public ::benchmark::Fixture {
|
|
public:
|
|
void SetUp(const ::benchmark::State& state) BENCHMARK_OVERRIDE {
|
|
if (state.thread_index == 0) {
|
|
assert(data.get() == nullptr);
|
|
data.reset(new int(42));
|
|
}
|
|
}
|
|
|
|
void TearDown(const ::benchmark::State& state) BENCHMARK_OVERRIDE {
|
|
if (state.thread_index == 0) {
|
|
assert(data.get() != nullptr);
|
|
data.reset();
|
|
}
|
|
}
|
|
|
|
~FIXTURE_BECHMARK_NAME() { assert(data == nullptr); }
|
|
|
|
std::unique_ptr<int> data;
|
|
};
|
|
|
|
BENCHMARK_F(FIXTURE_BECHMARK_NAME, Foo)(benchmark::State &st) {
|
|
assert(data.get() != nullptr);
|
|
assert(*data == 42);
|
|
for (auto _ : st) {
|
|
}
|
|
}
|
|
|
|
BENCHMARK_DEFINE_F(FIXTURE_BECHMARK_NAME, Bar)(benchmark::State& st) {
|
|
if (st.thread_index == 0) {
|
|
assert(data.get() != nullptr);
|
|
assert(*data == 42);
|
|
}
|
|
for (auto _ : st) {
|
|
assert(data.get() != nullptr);
|
|
assert(*data == 42);
|
|
}
|
|
st.SetItemsProcessed(st.range(0));
|
|
}
|
|
BENCHMARK_REGISTER_F(FIXTURE_BECHMARK_NAME, Bar)->Arg(42);
|
|
BENCHMARK_REGISTER_F(FIXTURE_BECHMARK_NAME, Bar)->Arg(42)->ThreadPerCpu();
|
|
|
|
BENCHMARK_MAIN();
|