mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-22 04:25:18 +00:00
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: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
parent
cc1d1dbbd5
commit
4b99ba98d0
@ -316,6 +316,7 @@ virHashAddOrUpdateEntry(virHashTablePtr table, const void *name,
|
||||
{
|
||||
size_t key, len = 0;
|
||||
virHashEntryPtr entry;
|
||||
virHashEntryPtr last = NULL;
|
||||
void *new_name;
|
||||
|
||||
if ((table == NULL) || (name == NULL))
|
||||
@ -337,6 +338,7 @@ virHashAddOrUpdateEntry(virHashTablePtr table, const void *name,
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
last = entry;
|
||||
len++;
|
||||
}
|
||||
|
||||
@ -347,8 +349,11 @@ virHashAddOrUpdateEntry(virHashTablePtr table, const void *name,
|
||||
|
||||
entry->name = new_name;
|
||||
entry->payload = userdata;
|
||||
entry->next = table->table[key];
|
||||
table->table[key] = entry;
|
||||
|
||||
if (last)
|
||||
last->next = entry;
|
||||
else
|
||||
table->table[key] = entry;
|
||||
|
||||
table->nbElems++;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user