Crates.io | integer-hasher |
lib.rs | integer-hasher |
version | 0.1.1 |
source | src |
created_at | 2022-10-28 04:52:33.193335 |
updated_at | 2022-11-17 10:04:52.010642 |
description | An implementation of `std::hash::Hasher` which does not hash at all. |
homepage | |
repository | https://github.com/NobodyXu/integer-hasher |
max_upload_size | |
id | 700103 |
size | 27,587 |
For an enabled type T
, a IntHasher<T>
implements std::hash::Hasher
and
uses the value set by one of the write_{u8, u16, u32, u64, usize, i8, i16, i32, i64, isize}
methods as its hash output.
IntHasher
does not implement any hashing algorithm and can only be used
with types which can be mapped directly to a numeric value. Out of the box
IntHasher
is enabled for u8
, u16
, u32
, u64
, usize
, i8
, i16
,
i32
, i64
, and isize
. Types that should be used with IntHasher
need
to implement [IsEnabled
] and by doing so assert that their Hash
impl invokes
only one of the Hasher::write_{u8, u16, u32, u64, usize, i8, i16, i32, i64, isize}
methods exactly once.
Note that for just like fxhash and other stable hashers, there are some performance drawback according to this blob.
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.