W3cubDocs

/Rust

Struct std::hash::BuildHasherDefault

pub struct BuildHasherDefault<H>(_);

Used to create a default BuildHasher instance for types that implement Hasher and Default.

BuildHasherDefault<H> can be used when a type H implements Hasher and Default, and you need a corresponding BuildHasher instance, but none is defined.

Any BuildHasherDefault is zero-sized. It can be created with default. When using BuildHasherDefault with HashMap or HashSet, this doesn't need to be done, since they implement appropriate Default instances themselves.

Examples

Using BuildHasherDefault to specify a custom BuildHasher for HashMap:

use std::collections::HashMap;
use std::hash::{BuildHasherDefault, Hasher};

#[derive(Default)]
struct MyHasher;

impl Hasher for MyHasher {
    fn write(&mut self, bytes: &[u8]) {
        // Your hashing algorithm goes here!
       unimplemented!()
    }

    fn finish(&self) -> u64 {
        // Your hashing algorithm goes here!
        unimplemented!()
    }
}

type MyBuildHasher = BuildHasherDefault<MyHasher>;

let hash_map = HashMap::<u32, u32, MyBuildHasher>::default();

Trait Implementations

impl<H> Default for BuildHasherDefault<H> [src]

[src]

Returns the "default value" for a type. Read more

impl<H> Clone for BuildHasherDefault<H> [src]

[src]

Returns a copy of the value. Read more

1.0.0
[src]

Performs copy-assignment from source. Read more

impl<H> BuildHasher for BuildHasherDefault<H> where
    H: Default + Hasher
[src]

Type of the hasher that will be created.

[src]

Creates a new hasher. Read more

impl<H> Debug for BuildHasherDefault<H>
1.9.0
[src]

[src]

Formats the value using the given formatter. Read more

© 2010 The Rust Project Developers
Licensed under the Apache License, Version 2.0 or the MIT license, at your option.
https://doc.rust-lang.org/std/hash/struct.BuildHasherDefault.html