pub struct NoHashHasher<T>(/* private fields */);
Expand description

For an enabled type T, a NoHashHasher<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.

NoHashHasher 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 NoHashHasher is enabled for u8, u16, u32, u64, usize, i8, i16, i32, i64, and isize. Types that should be used with NoHashHasher 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.

Examples

See also BuildNoHashHasher, IntMap and IntSet for some easier usage examples. See IsEnabled for use with custom types.

use solana_nohash_hasher::NoHashHasher;
use std::{collections::HashMap, hash::BuildHasherDefault};

let mut m: HashMap::<u8, char, BuildHasherDefault<NoHashHasher<u8>>> =
    HashMap::with_capacity_and_hasher(2, BuildHasherDefault::default());

m.insert(0, 'a');
m.insert(1, 'b');

assert_eq!(Some(&'a'), m.get(&0));
assert_eq!(Some(&'b'), m.get(&1));

Trait Implementations§

source§

impl<T> Clone for NoHashHasher<T>

source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<T> Debug for NoHashHasher<T>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<T> Default for NoHashHasher<T>

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl<T: IsEnabled> Hasher for NoHashHasher<T>

source§

fn write(&mut self, _: &[u8])

Writes some data into this Hasher. Read more
source§

fn write_u8(&mut self, n: u8)

Writes a single u8 into this hasher.
source§

fn write_u16(&mut self, n: u16)

Writes a single u16 into this hasher.
source§

fn write_u32(&mut self, n: u32)

Writes a single u32 into this hasher.
source§

fn write_u64(&mut self, n: u64)

Writes a single u64 into this hasher.
source§

fn write_usize(&mut self, n: usize)

Writes a single usize into this hasher.
source§

fn write_i8(&mut self, n: i8)

Writes a single i8 into this hasher.
source§

fn write_i16(&mut self, n: i16)

Writes a single i16 into this hasher.
source§

fn write_i32(&mut self, n: i32)

Writes a single i32 into this hasher.
source§

fn write_i64(&mut self, n: i64)

Writes a single i64 into this hasher.
source§

fn write_isize(&mut self, n: isize)

Writes a single isize into this hasher.
source§

fn finish(&self) -> u64

Returns the hash value for the values written so far. Read more
1.26.0 · source§

fn write_u128(&mut self, i: u128)

Writes a single u128 into this hasher.
1.26.0 · source§

fn write_i128(&mut self, i: i128)

Writes a single i128 into this hasher.
source§

fn write_length_prefix(&mut self, len: usize)

🔬This is a nightly-only experimental API. (hasher_prefixfree_extras)
Writes a length prefix into this hasher, as part of being prefix-free. Read more
source§

fn write_str(&mut self, s: &str)

🔬This is a nightly-only experimental API. (hasher_prefixfree_extras)
Writes a single str into this hasher. Read more
source§

impl<T> Copy for NoHashHasher<T>

Auto Trait Implementations§

§

impl<T> RefUnwindSafe for NoHashHasher<T>
where T: RefUnwindSafe,

§

impl<T> Send for NoHashHasher<T>
where T: Send,

§

impl<T> Sync for NoHashHasher<T>
where T: Sync,

§

impl<T> Unpin for NoHashHasher<T>
where T: Unpin,

§

impl<T> UnwindSafe for NoHashHasher<T>
where T: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.