2.3.1 Digest¶
Functions to generate a short “digest” of data with minimal collisions.
These are good general-purpose hash functions for indexing arbitrary data, but are not necessarily stable across platforms and should never be used for cryptographic purposes.
-
uint32_t zix_digest32(uint32_t seed, const void *buf, size_t len)¶
Return a 32-bit hash of a buffer.
This can be used for any size or alignment.
-
uint32_t zix_digest32_aligned(uint32_t seed, const void *buf, size_t len)¶
Return a 32-bit hash of an aligned buffer.
Both the buffer and size must be aligned to 32 bits. For data that fits these requirements, this is equivalent to, but faster than,
zix_digest32()
.
-
uint64_t zix_digest64(uint64_t seed, const void *buf, size_t len)¶
Return a 64-bit hash of a buffer.
This can be used for any size or alignment.
-
uint64_t zix_digest64_aligned(uint64_t seed, const void *buf, size_t len)¶
Return a 64-bit hash of an aligned buffer.
Both the buffer and size must be aligned to 64 bits. For data that fits these requirements, this is equivalent to, but faster than,
zix_digest64()
.
-
size_t zix_digest(size_t seed, const void *buf, size_t len)¶
Return a pointer-sized hash of a buffer.
This can be used for any size or alignment.
Internally, this simply dispatches to
zix_digest32()
orzix_digest64()
as appropriate.
-
size_t zix_digest_aligned(size_t seed, const void *buf, size_t len)¶
Return a pointer-sized hash of an aligned buffer.
Both the buffer and size must be aligned to the pointer size. For data that fits these requirements, this is equivalent to, but faster than,
zix_digest()
.Internally, this simply dispatches to
zix_digest32_aligned()
orzix_digest64_aligned()
as appropriate.