PHP 的 shuffle 函数有多随机?

2024-03-31

有谁知道PHP的随机性是什么shuffle()功能?它取决于操作系统吗? 它使用 PHP 自己的播种器吗?

是否可以使用mt_rand()作为发电机?


shuffle()函数基于相同的生成器rand(),这是基于的系统生成器线性同余算法 http://en.wikipedia.org/wiki/Linear_congruential_generator。这是一个快速生成器,但或多或​​少具有随机性。从 PHP 4.2.0 开始,随机生成器会自动播种,但您可以使用srand()如果需要的话,可以使用它来播种它。

mtrand()是基于梅森旋转算法 http://en.wikipedia.org/wiki/Mersenne_twister,这是可用的最好的伪随机算法之一。要使用该生成器对数组进行洗牌,您需要编写自己的洗牌函数。您可以查看例如Fisher-Yates 算法 http://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle。编写自己的 shuffle 函数将产生更好的随机性,但会比内置 shuffle 函数慢。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

PHP 的 shuffle 函数有多随机? 的相关文章

随机推荐