我正在尝试在 Go 中生成一个随机字符串,这是我到目前为止编写的代码:
package main
import (
"bytes"
"fmt"
"math/rand"
"time"
)
func main() {
fmt.Println(randomString(10))
}
func randomString(l int) string {
var result bytes.Buffer
var temp string
for i := 0; i < l; {
if string(randInt(65, 90)) != temp {
temp = string(randInt(65, 90))
result.WriteString(temp)
i++
}
}
return result.String()
}
func randInt(min int, max int) int {
rand.Seed(time.Now().UTC().UnixNano())
return min + rand.Intn(max-min)
}
我的实施非常缓慢。播种 usingtime
会在一定时间内带来相同的随机数,因此循环一次又一次地迭代。如何改进我的代码?
每次设置相同的种子时,都会得到相同的序列。因此,当然,如果您将种子设置为快速循环中的时间,您可能会多次使用相同的种子调用它。
在你的情况下,当你调用你的randInt
函数直到你有一个不同的值时,你正在等待时间(由 Nano 返回)改变。
对于所有伪随机库,您只需设置一次种子,例如在初始化程序时,除非您特别需要重现给定的序列(通常仅用于调试和单元测试)。
之后,您只需调用Intn
以获取下一个随机整数。
将rand.Seed(time.Now().UTC().UnixNano())
行从 randInt 函数移动到 main
的开头,一切都会更快。并失去了.UTC()
电话,因为:
UnixNano 返回 t 作为 Unix 时间,即自 1970 年 1 月 1 日 UTC 以来经过的纳秒数。
另请注意,我认为您可以简化字符串构建:
package main
import (
"fmt"
"math/rand"
"time"
)
func main() {
rand.Seed(time.Now().UnixNano())
fmt.Println(randomString(10))
}
func randomString(l int) string {
bytes := make([]byte, l)
for i := 0; i < l; i++ {
bytes[i] = byte(randInt(65, 90))
}
return string(bytes)
}
func randInt(min int, max int) int {
return min + rand.Intn(max-min)
}
golang框架如何对限流和熔断的监控指标进行收集?
在Go语言中,对指向数组的指针进行取值操作可以通过以下几种方式实现。假设我们有一个指向数组的指针,我们可以使用数组指针来访问数组的元素,或者通过解引用操作符来获取整个数组。下面是一个详细的示例和解释:package main import "fmt" func main() { // 声明并初始化一个数组 arr := [3]int{1, 2, 3} // 获取数组的指针 arrPtr := &arr // 方法1:通过数组指针直接访问数组元素 fm
golang框架在高并发场景下的性能调优策略?
进程结束时,信号量是如何自动释放的?
Flutter在Debian上运行体验如何
如何对涉及数据库交互的 Golang 函数进行单元测试?