Skip to content

Instantly share code, notes, and snippets.

@drewwells
Last active April 22, 2024 14:50
Show Gist options
  • Star 4 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save drewwells/6d332d7b1e333d69b108 to your computer and use it in GitHub Desktop.
Save drewwells/6d332d7b1e333d69b108 to your computer and use it in GitHub Desktop.
Go benchmark of md5, sha1, sha256
package bench
import (
"crypto/md5"
"crypto/rand"
"crypto/sha1"
"crypto/sha256"
"hash"
"testing"
)
func benchmarkRun(h hash.Hash, i int, b *testing.B) {
bs := make([]byte, i)
_, err := rand.Read(bs)
if err != nil {
b.Fatal(err)
}
b.ResetTimer()
for i := 0; i < b.N; i++ {
h.Write(bs)
h.Sum(nil)
}
}
func BenchmarkMD5_1k(b *testing.B) {
benchmarkRun(md5.New(), 1024, b)
}
func BenchmarkMD5_10k(b *testing.B) {
benchmarkRun(md5.New(), 10*1024, b)
}
func BenchmarkMD5_100k(b *testing.B) {
benchmarkRun(md5.New(), 100*1024, b)
}
func BenchmarkMD5_250k(b *testing.B) {
benchmarkRun(md5.New(), 250*1024, b)
}
func BenchmarkMD5_500k(b *testing.B) {
benchmarkRun(md5.New(), 500*1024, b)
}
func BenchmarkSHA11_1k(b *testing.B) {
benchmarkRun(sha1.New(), 1024, b)
}
func BenchmarkSha1_10k(b *testing.B) {
benchmarkRun(sha1.New(), 10*1024, b)
}
func BenchmarkSha1_100k(b *testing.B) {
benchmarkRun(sha1.New(), 100*1024, b)
}
func BenchmarkSha1_250k(b *testing.B) {
benchmarkRun(sha1.New(), 250*1024, b)
}
func BenchmarkSha1_500k(b *testing.B) {
benchmarkRun(sha1.New(), 500*1024, b)
}
func BenchmarkSha256_1k(b *testing.B) {
benchmarkRun(sha256.New(), 1024, b)
}
func BenchmarkSha256_10k(b *testing.B) {
benchmarkRun(sha256.New(), 10*1024, b)
}
func BenchmarkSha256_100k(b *testing.B) {
benchmarkRun(sha256.New(), 100*1024, b)
}
func BenchmarkSha256_250k(b *testing.B) {
benchmarkRun(sha256.New(), 250*1024, b)
}
func BenchmarkSha256_500k(b *testing.B) {
benchmarkRun(sha256.New(), 500*1024, b)
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment