Commit 5fbc511f authored by INADA Naoki's avatar INADA Naoki Committed by GitHub

bpo-33205: dict: Change GROWTH_RATE to `used*3` (GH-6350)

parent acfb087f
Change dict growth function from ``round_up_to_power_2(used*2+hashtable_size/2)`` to
``round_up_to_power_2(used*3)``. Previously, dict is shrinked only when ``used == 0``.
Now dict has more chance to be shrinked.
...@@ -396,17 +396,16 @@ dk_set_index(PyDictKeysObject *keys, Py_ssize_t i, Py_ssize_t ix) ...@@ -396,17 +396,16 @@ dk_set_index(PyDictKeysObject *keys, Py_ssize_t i, Py_ssize_t ix)
*/ */
/* GROWTH_RATE. Growth rate upon hitting maximum load. /* GROWTH_RATE. Growth rate upon hitting maximum load.
* Currently set to used*2 + capacity/2. * Currently set to used*3.
* This means that dicts double in size when growing without deletions, * This means that dicts double in size when growing without deletions,
* but have more head room when the number of deletions is on a par with the * but have more head room when the number of deletions is on a par with the
* number of insertions. * number of insertions. See also bpo-17563 and bpo-33205.
* Raising this to used*4 doubles memory consumption depending on the size of *
* the dictionary, but results in half the number of resizes, less effort to
* resize.
* GROWTH_RATE was set to used*4 up to version 3.2. * GROWTH_RATE was set to used*4 up to version 3.2.
* GROWTH_RATE was set to used*2 in version 3.3.0 * GROWTH_RATE was set to used*2 in version 3.3.0
* GROWTH_RATE was set to used*2 + capacity/2 in 3.4.0-3.6.0.
*/ */
#define GROWTH_RATE(d) (((d)->ma_used*2)+((d)->ma_keys->dk_size>>1)) #define GROWTH_RATE(d) ((d)->ma_used*3)
#define ENSURE_ALLOWS_DELETIONS(d) \ #define ENSURE_ALLOWS_DELETIONS(d) \
if ((d)->ma_keys->dk_lookup == lookdict_unicode_nodummy) { \ if ((d)->ma_keys->dk_lookup == lookdict_unicode_nodummy) { \
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment