pub struct IdentityHasher<T>(_, _, _);
Expand description

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

IdentityHasher 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 IdentityHasher is enabled for u8, u16, u32, u64, usize, i8, i16, i32, i64, and isize. Types that should be used with IdentityHasher need to implement IdentityHashable 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 BuildIdentityHasher, IntMap and IntSet for some easier usage examples. See IdentityHashable for use with custom types.

use identity_hash::IdentityHasher;
use std::{collections::HashMap, hash::BuildHasherDefault};

let mut m: HashMap::<u8, char, BuildHasherDefault<IdentityHasher<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 IdentityHasher<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 IdentityHasher<T>

source§

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

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

impl<T> Default for IdentityHasher<T>

source§

fn default() -> Self

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

impl<T: IdentityHashable> Hasher for IdentityHasher<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 IdentityHasher<T>

Auto Trait Implementations§

§

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

§

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

§

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

§

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

§

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

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

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

const: unstable · 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 Twhere 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 Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.