tree: c7e6513f180722fed349484f74407d02c26bcae3 [path history] [tgz]
  1. .cargo-checksum.json
  2. .cargo_vcs_info.json
  3. .travis.yml
  4. COPYING
  5. Cargo.toml
  6. LICENSE-MIT
  7. Makefile
  8. README.md
  9. UNLICENSE
  10. appveyor.yml
  11. build.rs
  12. ci/
  13. ctags.rust
  14. session.vim
  15. src/
rustc_deps/vendor/memchr/README.md

This crate provides a safe interface libc's memchr and memrchr. This crate also provides fallback implementations when either function is unavailable.

Build status Build status

Dual-licensed under MIT or the UNLICENSE.

Documentation

https://docs.rs/memchr

no_std

memchr links to the standard library by default, but you can disable the use_std feature if you want to use it in a #![no_std] crate:

[dependencies]
memchr = { version = "2", default-features = false }

Performance

On my system (Linux/amd64), memchr is about an order of magnitude faster than the more idiomatic haystack.iter().position(|&b| b == needle):

test iterator          ... bench:       5,280 ns/iter (+/- 13) = 1893 MB/s
test iterator_reversed ... bench:       5,271 ns/iter (+/- 7) = 1897 MB/s
test libc_memchr       ... bench:         202 ns/iter (+/- 0) = 49504 MB/s
test libc_memrchr      ... bench:         197 ns/iter (+/- 1) = 50761 MB/s