boulder/vendor/github.com/cespare/xxhash/v2
Phil Porada b61c7e1fdd
Upgrade go-redis from v9.3.0 to v9.4.0 (#7593)
Skip v9.3.1 and go straight to v9.4.0 because it's a fix for a
breaking change introduced in v9.3.1. I don't believe we can upgrade to
v9.5.x at this time because of our [redis container
version](fa3b0106e5/docker-compose.yml (L110-L111)).

Changes from
[v9.3.1](https://github.com/redis/go-redis/releases/tag/v9.3.1)
Changes from
[v9.4.0](https://github.com/redis/go-redis/releases/tag/v9.4.0)
2024-07-16 11:55:33 -04:00
..
LICENSE.txt deps: update to prometheus/client_golang 1.2.1 (#4601) 2019-12-06 16:14:50 -05:00
README.md Upgrade go-redis from v9.3.0 to v9.4.0 (#7593) 2024-07-16 11:55:33 -04:00
testall.sh Upgrade GRPC to v1.53.0 (#6734) 2023-03-15 12:36:04 -07:00
xxhash.go Upgrade go-redis from v9.3.0 to v9.4.0 (#7593) 2024-07-16 11:55:33 -04:00
xxhash_amd64.s Upgrade GRPC to v1.53.0 (#6734) 2023-03-15 12:36:04 -07:00
xxhash_arm64.s Upgrade GRPC to v1.53.0 (#6734) 2023-03-15 12:36:04 -07:00
xxhash_asm.go Upgrade go-redis from v9.3.0 to v9.4.0 (#7593) 2024-07-16 11:55:33 -04:00
xxhash_other.go Upgrade go-redis from v9.3.0 to v9.4.0 (#7593) 2024-07-16 11:55:33 -04:00
xxhash_safe.go Upgrade go-redis from v9.3.0 to v9.4.0 (#7593) 2024-07-16 11:55:33 -04:00
xxhash_unsafe.go Upgrade go-redis from v9.3.0 to v9.4.0 (#7593) 2024-07-16 11:55:33 -04:00

README.md

xxhash

Go Reference Test

xxhash is a Go implementation of the 64-bit xxHash algorithm, XXH64. This is a high-quality hashing algorithm that is much faster than anything in the Go standard library.

This package provides a straightforward API:

func Sum64(b []byte) uint64
func Sum64String(s string) uint64
type Digest struct{ ... }
    func New() *Digest

The Digest type implements hash.Hash64. Its key methods are:

func (*Digest) Write([]byte) (int, error)
func (*Digest) WriteString(string) (int, error)
func (*Digest) Sum64() uint64

The package is written with optimized pure Go and also contains even faster assembly implementations for amd64 and arm64. If desired, the purego build tag opts into using the Go code even on those architectures.

Compatibility

This package is in a module and the latest code is in version 2 of the module. You need a version of Go with at least "minimal module compatibility" to use github.com/cespare/xxhash/v2:

  • 1.9.7+ for Go 1.9
  • 1.10.3+ for Go 1.10
  • Go 1.11 or later

I recommend using the latest release of Go.

Benchmarks

Here are some quick benchmarks comparing the pure-Go and assembly implementations of Sum64.

input size purego asm
4 B 1.3 GB/s 1.2 GB/s
16 B 2.9 GB/s 3.5 GB/s
100 B 6.9 GB/s 8.1 GB/s
4 KB 11.7 GB/s 16.7 GB/s
10 MB 12.0 GB/s 17.3 GB/s

These numbers were generated on Ubuntu 20.04 with an Intel Xeon Platinum 8252C CPU using the following commands under Go 1.19.2:

benchstat <(go test -tags purego -benchtime 500ms -count 15 -bench 'Sum64$')
benchstat <(go test -benchtime 500ms -count 15 -bench 'Sum64$')

Projects using this package