提交 4b99ba98 编写于 作者: P Peter Krempa

util: hash: Append to hash buckets when adding new entries

In cases when the hash function for a name collides with other entry
already in the hash we prepend to the bucket. This creates a 'stack
effect' on the buckets if we then iterate through the hash. Normally
this is not a problem, but in tests we want deterministic results.

Since it does not matter where we add the entry and it's usually more
probable that a different entry will be accessed next change it to
append to the end of the bucket. Luckily we already iterate throught the
bucket once thus we can easily find the last entry and just connect the
new entry after it.
Signed-off-by: NPeter Krempa <pkrempa@redhat.com>
Reviewed-by: NDaniel P. Berrangé <berrange@redhat.com>
上级 cc1d1dbb
...@@ -316,6 +316,7 @@ virHashAddOrUpdateEntry(virHashTablePtr table, const void *name, ...@@ -316,6 +316,7 @@ virHashAddOrUpdateEntry(virHashTablePtr table, const void *name,
{ {
size_t key, len = 0; size_t key, len = 0;
virHashEntryPtr entry; virHashEntryPtr entry;
virHashEntryPtr last = NULL;
void *new_name; void *new_name;
if ((table == NULL) || (name == NULL)) if ((table == NULL) || (name == NULL))
...@@ -337,6 +338,7 @@ virHashAddOrUpdateEntry(virHashTablePtr table, const void *name, ...@@ -337,6 +338,7 @@ virHashAddOrUpdateEntry(virHashTablePtr table, const void *name,
return -1; return -1;
} }
} }
last = entry;
len++; len++;
} }
...@@ -347,7 +349,10 @@ virHashAddOrUpdateEntry(virHashTablePtr table, const void *name, ...@@ -347,7 +349,10 @@ virHashAddOrUpdateEntry(virHashTablePtr table, const void *name,
entry->name = new_name; entry->name = new_name;
entry->payload = userdata; entry->payload = userdata;
entry->next = table->table[key];
if (last)
last->next = entry;
else
table->table[key] = entry; table->table[key] = entry;
table->nbElems++; table->nbElems++;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册