From: François Dumont Date: Thu, 8 Nov 2012 20:16:04 +0000 (+0000) Subject: re PR libstdc++/54075 ([4.7.1] unordered_map insert still slower than 4.6.2) X-Git-Tag: releases/gcc-4.8.0~2137 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=ecf07a67d0e8cc33b780783d9996a0e91a6239a2;p=thirdparty%2Fgcc.git re PR libstdc++/54075 ([4.7.1] unordered_map insert still slower than 4.6.2) 2012-11-08 François Dumont PR libstdc++/54075 * include/bits/hashtable.h (_Hashtable<>::rehash): Reset hash policy state if no rehash. * testsuite/23_containers/unordered_set/modifiers/reserve.cc (test02): New. From-SVN: r193339 --- diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index db8a1abcc97d..a65679998394 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,3 +1,11 @@ +2012-11-08 François Dumont + + PR libstdc++/54075 + * include/bits/hashtable.h (_Hashtable<>::rehash): Reset hash + policy state if no rehash. + * testsuite/23_containers/unordered_set/modifiers/reserve.cc + (test02): New. + 2012-11-08 Paolo Carlini * testsuite/23_containers/unordered_multimap/insert/55028-debug.cc: diff --git a/libstdc++-v3/include/bits/hashtable.h b/libstdc++-v3/include/bits/hashtable.h index 8ceacabce121..9b2677b098ad 100644 --- a/libstdc++-v3/include/bits/hashtable.h +++ b/libstdc++-v3/include/bits/hashtable.h @@ -1654,6 +1654,9 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION // level. _M_rehash_policy._M_prev_resize = 0; } + else + // No rehash, restore previous state to keep a consistent state. + _M_rehash_policy._M_reset(__saved_state); } template Set; + Set s; + s.reserve(N); + s.reserve(N); + + std::size_t bkts = s.bucket_count(); + for (int i = 0; i != N; ++i) + { + s.insert(i); + // As long as we insert less than the reserved number of elements we + // shouldn't experiment any rehash. + VERIFY( s.bucket_count() == bkts ); + } +} + int main() { test01(); + test02(); return 0; }