diff options
| author | Eric Fiselier <eric@efcs.ca> | 2018-07-10 04:11:22 +0000 |
|---|---|---|
| committer | Eric Fiselier <eric@efcs.ca> | 2018-07-10 04:11:22 +0000 |
| commit | 09701324a1d0926b8ea2ba026a094cf6957f9ea5 (patch) | |
| tree | 1e063729965864c31a53c59a6eb1ee1cfa9a8656 | |
| parent | fcafd3e6002cb682d737ddf56f1d972358dbfa61 (diff) | |
| download | bcm5719-llvm-09701324a1d0926b8ea2ba026a094cf6957f9ea5.tar.gz bcm5719-llvm-09701324a1d0926b8ea2ba026a094cf6957f9ea5.zip | |
Add new string benchmarks
llvm-svn: 336636
| -rw-r--r-- | libcxx/benchmarks/string.bench.cpp | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/libcxx/benchmarks/string.bench.cpp b/libcxx/benchmarks/string.bench.cpp index 8324f3e99bb..8a09e738d9b 100644 --- a/libcxx/benchmarks/string.bench.cpp +++ b/libcxx/benchmarks/string.bench.cpp @@ -46,4 +46,25 @@ static void BM_StringFindMatch2(benchmark::State &state) { } BENCHMARK(BM_StringFindMatch2)->Range(1, MAX_STRING_LEN / 4); +static void BM_StringCtorDefault(benchmark::State &state) { + while (state.KeepRunning()) { + for (unsigned I=0; I < 1000; ++I) { + std::string Default; + benchmark::DoNotOptimize(Default.c_str()); + } + } +} +BENCHMARK(BM_StringCtorDefault); + +static void BM_StringCtorCStr(benchmark::State &state) { + std::string Input = getRandomString(state.range(0)); + const char *Str = Input.c_str(); + benchmark::DoNotOptimize(Str); + while (state.KeepRunning()) { + std::string Tmp(Str); + benchmark::DoNotOptimize(Tmp.c_str()); + } +} +BENCHMARK(BM_StringCtorCStr)->Arg(1)->Arg(8)->Range(16, MAX_STRING_LEN / 4); + BENCHMARK_MAIN(); |

