#hash #hashing #performance #cache #hash-values #wrapper

hash_on_write

A wrapper for storing hash results to avoid running costly hash functions multiple times without modifying the value

9 unstable releases (3 breaking)

0.4.4 Nov 6, 2024
0.4.3 Jun 14, 2024
0.3.1 Jun 13, 2024
0.2.0 Jun 8, 2024
0.1.0 Jun 8, 2024

#125 in Caching

MIT license

21KB
538 lines

A wrapper for storing hash results to avoid running costly hash functions multiple times without modifying the value

Due to Rust's abstraction of the hash system, it can currently only be implemented as a hash that uses another internal Hasher for values

Example

use hash_on_write::How;
use std::collections::HashSet;

let mut x = How::new_default("foo".to_owned());

assert!(! How::is_hashed(&x));
HashSet::new().insert(&x);
assert!(How::is_hashed(&x));

How::make_mut(&mut x).push('!');
assert!(! How::is_hashed(&x));
assert_eq!(*x, "foo!");

bench

Warning: Unable to complete 100 samples in 5.0s. You may wish to increase target time to 8.2s, or reduce sample count to 60.
no cache                time:   [81.408 ms 81.529 ms 81.673 ms]
                        change: [-0.7393% -0.4157% -0.1121%] (p = 0.01 < 0.05)
                        Change within noise threshold.
Found 5 outliers among 100 measurements (5.00%)
  2 (2.00%) low mild
  2 (2.00%) high mild
  1 (1.00%) high severe

Benchmarking cache key: Warming up for 3.0000 s
Warning: Unable to complete 100 samples in 5.0s. You may wish to increase target time to 5.3s, or reduce sample count to 90.
cache key               time:   [53.380 ms 53.608 ms 53.855 ms]
                        change: [-0.6099% +0.0048% +0.5883%] (p = 0.99 > 0.05)
                        No change in performance detected.
Found 5 outliers among 100 measurements (5.00%)
  4 (4.00%) high mild
  1 (1.00%) high severe

No runtime deps