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
|
||||||
|
}
|
Загрузка…
Создание таблицы
Сослаться в новой задаче