From: Phil Willoughby Date: Tue, 19 Sep 2017 20:57:36 +0000 (-0700) Subject: Benchmark a realistic common use X-Git-Tag: v2017.09.25.00~6 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=3619b401a7d7e2f1a3454ad04639831f8a2c224b;p=folly.git Benchmark a realistic common use Summary: We didn't previously benchmark the performance of `get()`, which was a strange omission. Reviewed By: akrieger Differential Revision: D5863567 fbshipit-source-id: 468b249da9120fcb84f3303ac5e2157761b6369d --- diff --git a/folly/futures/test/Benchmark.cpp b/folly/futures/test/Benchmark.cpp index f6d838d8..770a830e 100644 --- a/folly/futures/test/Benchmark.cpp +++ b/folly/futures/test/Benchmark.cpp @@ -290,6 +290,44 @@ BENCHMARK_RELATIVE(throwWrappedAndCatchWrappedContended) { contend(throwWrappedAndCatchWrappedImpl); } +BENCHMARK_DRAW_LINE(); + +namespace { +struct Bulky { + explicit Bulky(std::string message) : message_(message) {} + std::string message() & { + return message_; + } + std::string&& message() && { + return std::move(message_); + } + + private: + std::string message_; + std::array ints_; +}; +} // anonymous namespace + +BENCHMARK(lvalue_get) { + BenchmarkSuspender suspender; + Optional> future; + future = makeFuture(Bulky("Hello")); + suspender.dismissing([&] { + std::string message = future.value().get().message(); + doNotOptimizeAway(message); + }); +} + +BENCHMARK_RELATIVE(rvalue_get) { + BenchmarkSuspender suspender; + Optional> future; + future = makeFuture(Bulky("Hello")); + suspender.dismissing([&] { + std::string message = std::move(future.value()).get().message(); + doNotOptimizeAway(message); + }); +} + InlineExecutor exe; template