runtime: add fastrand
This is needed for hash/maphash support.
Этот коммит содержится в:
родитель
0791603c86
коммит
4c28f1b875
1 изменённых файлов: 22 добавлений и 0 удалений
22
src/runtime/algorithm.go
Обычный файл
22
src/runtime/algorithm.go
Обычный файл
|
@ -0,0 +1,22 @@
|
|||
package runtime
|
||||
|
||||
// This file implements various core algorithms used in the runtime package and
|
||||
// standard library.
|
||||
|
||||
// This function is used by hash/maphash.
|
||||
func fastrand() uint32 {
|
||||
xorshift32State = xorshift32(xorshift32State)
|
||||
return xorshift32State
|
||||
}
|
||||
|
||||
var xorshift32State uint32 = 1
|
||||
|
||||
func xorshift32(x uint32) uint32 {
|
||||
// Algorithm "xor" from p. 4 of Marsaglia, "Xorshift RNGs".
|
||||
// Improved sequence based on
|
||||
// http://www.iro.umontreal.ca/~lecuyer/myftp/papers/xorshift.pdf
|
||||
x ^= x << 7
|
||||
x ^= x >> 1
|
||||
x ^= x << 9
|
||||
return x
|
||||
}
|
Загрузка…
Создание таблицы
Сослаться в новой задаче