#xx-hash #hasher #hash #xxh3

no-std twox-hash

A Rust implementation of the XXHash and XXH3 algorithms

16 stable releases

2.1.0 Dec 9, 2024
2.0.1 Nov 4, 2024
2.0.0 Oct 18, 2024
1.6.3 May 4, 2022
0.1.1 Jul 20, 2015

#3 in Algorithms

Download history 667358/week @ 2024-09-23 682382/week @ 2024-09-30 706594/week @ 2024-10-07 697641/week @ 2024-10-14 707545/week @ 2024-10-21 661180/week @ 2024-10-28 709392/week @ 2024-11-04 704646/week @ 2024-11-11 679445/week @ 2024-11-18 559203/week @ 2024-11-25 686447/week @ 2024-12-02 896638/week @ 2024-12-09 790303/week @ 2024-12-16 303225/week @ 2024-12-23 440440/week @ 2024-12-30 839129/week @ 2025-01-06

2,403,931 downloads per month
Used in 2,090 crates (202 directly)

MIT license

145KB
3.5K SLoC

A Rust implementation of the xxHash algorithm.

Crates.io Documentation Build Status

Examples

These examples use XxHash64 but the same ideas can be used for XxHash32 or XxHash3_64.

Hashing arbitrary data

When all the data is available at once

use twox_hash::XxHash64;

let seed = 1234;
let hash = XxHash64::oneshot(seed, b"some bytes");
assert_eq!(0xeab5_5659_a496_d78b, hash);

When the data is streaming

use std::hash::Hasher as _;
use twox_hash::XxHash64;

let seed = 1234;
let mut hasher = XxHash64::with_seed(seed);
hasher.write(b"some");
hasher.write(b" ");
hasher.write(b"bytes");
let hash = hasher.finish();
assert_eq!(0xeab5_5659_a496_d78b, hash);

In a HashMap

With a default seed

use std::{collections::HashMap, hash::BuildHasherDefault};
use twox_hash::XxHash64;

let mut hash = HashMap::<_, _, BuildHasherDefault<XxHash64>>::default();
hash.insert(42, "the answer");
assert_eq!(hash.get(&42), Some(&"the answer"));

With a random seed

use std::collections::HashMap;
use twox_hash::xxhash64;

let mut hash = HashMap::<_, _, xxhash64::RandomState>::default();
hash.insert(42, "the answer");
assert_eq!(hash.get(&42), Some(&"the answer"));

With a fixed seed

use std::collections::HashMap;
use twox_hash::xxhash64;

let mut hash = HashMap::with_hasher(xxhash64::State::with_seed(0xdead_cafe));
hash.insert(42, "the answer");
assert_eq!(hash.get(&42), Some(&"the answer"));

Feature Flags

name description
xxhash32 Include the XxHash32 algorithm
xxhash64 Include the XxHash64 algorithm
xxhash3_64 Include the XxHash3_64 algorithm
random Create random instances of the hashers
serialize Serialize and deserialize hasher state with Serde
std Use the Rust standard library. Enable this if you want SIMD support in XxHash3_64
alloc Use the Rust allocator library. Enable this if you want to create XxHash3_64 with dynamic secrets

Benchmarks

See benchmarks in the comparison README.

Contributing

  1. Fork it (https://github.com/shepmaster/twox-hash/fork)
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Add a failing test.
  4. Add code to pass the test.
  5. Commit your changes (git commit -am 'Add some feature')
  6. Ensure tests pass.
  7. Push to the branch (git push origin my-new-feature)
  8. Create a new Pull Request

Dependencies

~0–490KB