Golang 优雅地生成随机字符串
随机字符串都不保证唯一性,服务启动时需要对全局随机种子进行初始化
func init() {
rand.Seed(time.Now().UnixNano())
}
方法一 (常见,但不优雅
)
func GetRandomString(n int) string {
str := "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"
bytes := []byte(str)
var result []byte
for i := 0; i < n; i++ {
result = append(result, bytes[rand.Intn(len(bytes))])
}
return string(result)
}
Benchmark压力测试 8018 ns/op
方法二(Docker ContainerID
生成方法)
func GetRandomString2(n int) string {
randBytes := make([]byte, n/2)
rand.Read(randBytes)
return fmt.Sprintf("%x", randBytes)
}
Benchmark压力测试 10595 ns/op
有疑问加站长微信联系(非本文作者)

效率好差
怎么评判的?
写法问题,我来优化,第一个就不可能那么低效率
太误导人了,简单优化后,第一种做法只需要254 ns/op,果然很多人都是不懂装懂,误导人
能减少随机次数吗 O(n)的现在
压测的时候就不要标准输出了啊,本来标准输出效率就很差
优化后的代码呢
这还需要代码?你随便把result预先make好长度,都不知道快多少倍,str这种东西还要转成[]byte,都不知道损失多少性能,一看就是入门没学好
上面代码不可用,太多内存分配了,切片在已经长度的时候直接分配容器大小或者长度是最合适的,而且直接用字节数组代表字符串不好吗