const-hex

github crates.io docs.rs build status

This crate provides a fast conversion of byte arrays to hexadecimal strings, both at compile time, and at run time.

Extends the [hex] crate's implementation with [const-eval], a const-generics formatting buffer, similar to [itoa]'s, and more.

Version requirement: rustc 1.64+

Performance

This crate is ~10 times faster than [hex] in encoding, and 30+ times faster than libstd in formatting.

You can run the following benchmarks with cargo bench on a nightly compiler.

log test encode_const_hex::bench1_32 ... bench: 1 ns/iter (+/- 0) test encode_const_hex::bench2_128 ... bench: 5 ns/iter (+/- 0) test encode_const_hex::bench3_4096 ... bench: 204 ns/iter (+/- 9) test encode_hex::bench1_32 ... bench: 15 ns/iter (+/- 1) test encode_hex::bench2_128 ... bench: 60 ns/iter (+/- 2) test encode_hex::bench3_4096 ... bench: 1,703 ns/iter (+/- 50) test format_const_hex::bench1_32 ... bench: 15 ns/iter (+/- 0) test format_const_hex::bench2_128 ... bench: 20 ns/iter (+/- 0) test format_const_hex::bench3_4096 ... bench: 380 ns/iter (+/- 9) test format_std::bench1_32 ... bench: 470 ns/iter (+/- 4) test format_std::bench2_128 ... bench: 1,961 ns/iter (+/- 17) test format_std::bench3_4096 ... bench: 61,688 ns/iter (+/- 1,994)

Acknowledgements

License

Licensed under either of Apache License, Version 2.0 or MIT license at your option.

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.