//===----------------------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // UNSUPPORTED: c++03, c++11, c++14, c++17 // Don't warn about std::sprintf // ADDITIONAL_COMPILE_FLAGS: -Wno-deprecated #include #include #include #include #include #include #include #include #include #include #include "benchmark/benchmark.h" #include "test_macros.h" const char* c_string_6_characters = "abcdef"; const char* c_string_60_characters = "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef"; const char* c_string_6000_characters = "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef" "abcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdefabcdef"; // 100 lines std::string string_6_characters = c_string_6_characters; std::string string_60_characters = c_string_60_characters; std::string string_6000_characters = c_string_6000_characters; std::string_view string_view_6_characters = c_string_6_characters; std::string_view string_view_60_characters = c_string_60_characters; std::string_view string_view_6000_characters = c_string_6000_characters; static void BM_sprintf(benchmark::State& state, const char* value) { std::array output; for (auto _ : state) benchmark::DoNotOptimize(std::sprintf(output.data(), "%s", value)); } template static void BM_format(benchmark::State& state, const T& value) { for (auto _ : state) benchmark::DoNotOptimize(std::format("{}", value)); } template static void BM_format_to_back_inserter(benchmark::State& state, const T& value) { for (auto _ : state) { Container c; std::format_to(std::back_inserter(c), "{}", value); benchmark::DoNotOptimize(c); } } template static void BM_format_to_iterator(benchmark::State& state, const T& value, F&& f) { auto output = f(); for (auto _ : state) { benchmark::DoNotOptimize(std::format_to(std::begin(output), "{}", value)); } } #define FORMAT_BENCHMARKS(name, variable) \ BENCHMARK_CAPTURE(BM_format, name, variable); \ \ BENCHMARK_TEMPLATE1_CAPTURE(BM_format_to_back_inserter, std::string, name, variable); \ BENCHMARK_TEMPLATE1_CAPTURE(BM_format_to_back_inserter, std::vector, name, variable); \ BENCHMARK_TEMPLATE1_CAPTURE(BM_format_to_back_inserter, std::deque, name, variable); \ BENCHMARK_TEMPLATE1_CAPTURE(BM_format_to_back_inserter, std::list, name, variable); \ \ BENCHMARK_CAPTURE(BM_format_to_iterator, name, variable, ([] { \ std::array a; \ return a; \ })); \ BENCHMARK_CAPTURE(BM_format_to_iterator, name, variable, ([] { \ std::string s; \ s.resize(10'000); \ return s; \ })); \ BENCHMARK_CAPTURE(BM_format_to_iterator, name, variable, ([] { \ std::vector v; \ v.resize(10'000); \ return v; \ })); \ BENCHMARK_CAPTURE(BM_format_to_iterator, name, variable, ([] { \ std::deque d; \ d.resize(10'000); \ return d; \ })); \ \ /* */ BENCHMARK_CAPTURE(BM_sprintf, C_string_len_6, c_string_6_characters); FORMAT_BENCHMARKS(C_string_len_6, c_string_6_characters) FORMAT_BENCHMARKS(string_len_6, string_6_characters) FORMAT_BENCHMARKS(string_view_len_6, string_view_6_characters) BENCHMARK_CAPTURE(BM_sprintf, C_string_len_60, c_string_60_characters); FORMAT_BENCHMARKS(C_string_len_60, c_string_60_characters) FORMAT_BENCHMARKS(string_len_60, string_60_characters) FORMAT_BENCHMARKS(string_view_len_60, string_view_60_characters) BENCHMARK_CAPTURE(BM_sprintf, C_string_len_6000, c_string_6000_characters); FORMAT_BENCHMARKS(C_string_len_6000, c_string_6000_characters) FORMAT_BENCHMARKS(string_len_6000, string_6000_characters) FORMAT_BENCHMARKS(string_view_len_6000, string_view_6000_characters) BENCHMARK_MAIN();