Skip to main content

DefaultHasher

Struct DefaultHasher 

Source
pub struct DefaultHasher { /* private fields */ }
Expand description

A fast, non-cryptographic 64-bit hasher with strong avalanche behaviour.

DefaultHasher folds the input eight bytes at a time through a 64x64-bit multiply-fold and mixes the total length into the finalizer, so inputs that differ only by trailing zero bytes do not collide. It is not suitable for authentication or any setting where collision resistance against an adversary is required; use a cryptographic hash for that.

You rarely construct this directly. It is produced by DefaultHashBuilder, which the structures use by default.

§Examples

use core::hash::{Hash, Hasher};
use bloom_lib::hash::DefaultHasher;

let mut hasher = DefaultHasher::default();
"probabilistic".hash(&mut hasher);
let digest = hasher.finish();

// Hashing the same value again yields the same digest.
let mut again = DefaultHasher::default();
"probabilistic".hash(&mut again);
assert_eq!(digest, again.finish());

Implementations§

Source§

impl DefaultHasher

Source

pub const fn with_seed(seed: u64) -> Self

Creates a hasher seeded with the given value.

Two hashers created with the same seed produce identical digests for identical inputs. DefaultHasher::default uses a fixed library seed.

§Examples
use core::hash::Hasher;
use bloom_lib::hash::DefaultHasher;

let mut a = DefaultHasher::with_seed(42);
let mut b = DefaultHasher::with_seed(7);
a.write(b"payload");
b.write(b"payload");
assert_ne!(a.finish(), b.finish());

Trait Implementations§

Source§

impl Clone for DefaultHasher

Source§

fn clone(&self) -> DefaultHasher

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for DefaultHasher

Source§

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

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

impl Default for DefaultHasher

Source§

fn default() -> Self

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

impl Hasher for DefaultHasher

Source§

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

Writes some data into this Hasher. Read more
Source§

fn finish(&self) -> u64

Returns the hash value for the values written so far. Read more
1.3.0 · Source§

fn write_u8(&mut self, i: u8)

Writes a single u8 into this hasher.
1.3.0 · Source§

fn write_u16(&mut self, i: u16)

Writes a single u16 into this hasher.
1.3.0 · Source§

fn write_u32(&mut self, i: u32)

Writes a single u32 into this hasher.
1.3.0 · Source§

fn write_u64(&mut self, i: u64)

Writes a single u64 into this hasher.
1.26.0 · Source§

fn write_u128(&mut self, i: u128)

Writes a single u128 into this hasher.
1.3.0 · Source§

fn write_usize(&mut self, i: usize)

Writes a single usize into this hasher.
1.3.0 · Source§

fn write_i8(&mut self, i: i8)

Writes a single i8 into this hasher.
1.3.0 · Source§

fn write_i16(&mut self, i: i16)

Writes a single i16 into this hasher.
1.3.0 · Source§

fn write_i32(&mut self, i: i32)

Writes a single i32 into this hasher.
1.3.0 · Source§

fn write_i64(&mut self, i: i64)

Writes a single i64 into this hasher.
1.26.0 · Source§

fn write_i128(&mut self, i: i128)

Writes a single i128 into this hasher.
1.3.0 · Source§

fn write_isize(&mut self, i: isize)

Writes a single isize 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

Auto Trait Implementations§

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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,

Source§

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>,

Source§

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>,

Source§

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.