或者我必须使用直截了当的方式:
var arr []int
for i := 0; i < 5; i++ {
arr = append(arr, rand.Intn(100))
}
你做的很干净,也很快。您可以改进的是预先分配切片并使用for.. range
循环填充它,如下所示:
s := make([]int, 5)
for i := range s {
s[i] = rand.Intn(100)
}
math/rand
包还有一个rand.Read()
函数,用随机字节填充切片。因此,如果您想用随机数据填充[]byte
切片,这就是所需要的:
s := make([]byte, 100)
rand.Read(s) // This never returns an error
另一个有趣的方式是利用rand.Rand
作为io.Reader
。这意味着它有一个Read()
方法,用随机数据填充[]byte
。
结合encoding/binary
包,您可以使用随机数据“填充”变量。创建并将rand.Rand
传递给binary.Read()
函数作为源,就是这样。
这是它的样子:
r := rand.New(rand.NewSource(time.Now().UnixNano()))
s := make([]int32, 5)
err := binary.Read(r, binary.BigEndian, &s)
if err != nil {
panic(err)
}
fmt.Println(s)
输出:
[203443513 1611652563 -235795288 8294855 -802604260]
这很“酷”,甚至可以填充结构,例如:
var point struct{ X, Y int16 }
err = binary.Read(r, binary.BigEndian, &point)
if err != nil {
panic(err)
}
fmt.Printf("%+v", point)
输出:
{X:-15471 Y:2619}
在Go Playground上试试这些例子。
使用binary.Read()
的一个障碍是 - 可以理解 - 它只能填充固定大小类型的值,最着名的例外是常见的int
类型,其大小不固定(取决于架构)。所以你不能用[]int
类型的字段填充int
切片或结构。这就是我在上面的例子中使用int32
和int16
类型的原因。
当然,在这些解决方案中,您无法限制用于填充变量的随机数范围。为此,初始循环仍然更容易。