funcRandStringBytesRmndr(n int)string { b := make([]byte, n) for i := range b { b[i] = letterBytes[rand.Int63() % int64(len(letterBytes))] } returnstring(b) }
const letterBytes = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" const ( letterIdxBits = 6// 6 bits to represent a letter index letterIdxMask = 1<<letterIdxBits - 1// All 1-bits, as many as letterIdxBits )
funcRandStringBytesMask(n int)string { b := make([]byte, n) for i := 0; i < n; { if idx := int(rand.Int63() & letterIdxMask); idx < len(letterBytes) { b[i] = letterBytes[idx] i++ } } returnstring(b) }
const letterBytes = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" const ( letterIdxBits = 6// 6 bits to represent a letter index letterIdxMask = 1<<letterIdxBits - 1// All 1-bits, as many as letterIdxBits letterIdxMax = 63 / letterIdxBits // # of letter indices fitting in 63 bits )
funcRandStringBytesMaskImpr(n int)string { b := make([]byte, n) // A rand.Int63() generates 63 random bits, enough for letterIdxMax letters! for i, cache, remain := n-1, rand.Int63(), letterIdxMax; i >= 0; { if remain == 0 { cache, remain = rand.Int63(), letterIdxMax } if idx := int(cache & letterIdxMask); idx < len(letterBytes) { b[i] = letterBytes[idx] i-- } cache >>= letterIdxBits remain-- }
var letterRunes = []rune("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ")
funcRandStringRunes(n int)string { b := make([]rune, n) for i := range b { b[i] = letterRunes[rand.Intn(len(letterRunes))] } returnstring(b) }
const letterBytes = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" const ( letterIdxBits = 6// 6 bits to represent a letter index letterIdxMask = 1<<letterIdxBits - 1// All 1-bits, as many as letterIdxBits letterIdxMax = 63 / letterIdxBits // # of letter indices fitting in 63 bits )
funcRandStringBytes(n int)string { b := make([]byte, n) for i := range b { b[i] = letterBytes[rand.Intn(len(letterBytes))] } returnstring(b) }
funcRandStringBytesRmndr(n int)string { b := make([]byte, n) for i := range b { b[i] = letterBytes[rand.Int63()%int64(len(letterBytes))] } returnstring(b) }
funcRandStringBytesMask(n int)string { b := make([]byte, n) for i := 0; i < n; { if idx := int(rand.Int63() & letterIdxMask); idx < len(letterBytes) { b[i] = letterBytes[idx] i++ } } returnstring(b) }
funcRandStringBytesMaskImpr(n int)string { b := make([]byte, n) // A rand.Int63() generates 63 random bits, enough for letterIdxMax letters! for i, cache, remain := n-1, rand.Int63(), letterIdxMax; i >= 0; { if remain == 0 { cache, remain = rand.Int63(), letterIdxMax } if idx := int(cache & letterIdxMask); idx < len(letterBytes) { b[i] = letterBytes[idx] i-- } cache >>= letterIdxBits remain-- }
returnstring(b) }
var src = rand.NewSource(time.Now().UnixNano())
funcRandStringBytesMaskImprSrc(n int)string { b := make([]byte, n) // A src.Int63() generates 63 random bits, enough for letterIdxMax characters! for i, cache, remain := n-1, src.Int63(), letterIdxMax; i >= 0; { if remain == 0 { cache, remain = src.Int63(), letterIdxMax } if idx := int(cache & letterIdxMask); idx < len(letterBytes) { b[i] = letterBytes[idx] i-- } cache >>= letterIdxBits remain-- }
returnstring(b) }
// Benchmark functions
const n = 16
funcBenchmarkRunes(b *testing.B) { for i := 0; i < b.N; i++ { RandStringRunes(n) } }
funcBenchmarkBytes(b *testing.B) { for i := 0; i < b.N; i++ { RandStringBytes(n) } }
funcBenchmarkBytesRmndr(b *testing.B) { for i := 0; i < b.N; i++ { RandStringBytesRmndr(n) } }
funcBenchmarkBytesMask(b *testing.B) { for i := 0; i < b.N; i++ { RandStringBytesMask(n) } }
funcBenchmarkBytesMaskImpr(b *testing.B) { for i := 0; i < b.N; i++ { RandStringBytesMaskImpr(n) } }
funcBenchmarkBytesMaskImprSrc(b *testing.B) { for i := 0; i < b.N; i++ { RandStringBytesMaskImprSrc(n) } }