How random is PHP#39;s shuffle function?(PHP 的 shuffle 函数有多随机?)
问题描述
有谁知道 PHP 的 shuffle()
函数的随机性是什么?它取决于操作系统吗?它是否使用 PHP 自己的播种机?
Does anyone know what's the randomness of PHP's shuffle()
function? Does it depend on the operating system?
Does it use PHP's own seeder?
是否可以使用 mt_rand()
作为生成器?
Is it possible to use mt_rand()
as generator?
推荐答案
shuffle()
函数基于与 rand()
相同的生成器,也就是系统基于线性同余算法的生成器.这是一个快速生成器,但或多或少具有随机性.自 PHP 4.2.0 起,随机生成器会自动播种,但您可以根据需要使用 srand()
函数来播种.
shuffle()
function is based on the same generator as rand()
, which is the system generator based on linear congruential algorithm. This is a fast generator, but with more or less randomness. Since PHP 4.2.0, the random generator is seeded automatically, but you can use srand()
function to seed it if you want.
mtrand()
基于 Mersenne Twister 算法,其中是最好的伪随机算法之一.要使用该生成器对数组进行混洗,您需要编写自己的 shuffle 函数.例如,您可以查看 Fisher-Yates 算法.编写自己的 shuffle 函数会产生更好的随机性,但会比内置的 shuffle 函数慢.
mtrand()
is based on Mersenne Twister algorithm, which is one of the best pseudo-random algorithms available. To shuffle an array using that generator, you'd need to write you own shuffle function. You can look for example at Fisher-Yates algorithm. Writing you own shuffle function will yield to better randomness, but will be slower than the builtin shuffle function.
这篇关于PHP 的 shuffle 函数有多随机?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:PHP 的 shuffle 函数有多随机?
基础教程推荐
- PHP 守护进程/worker 环境 2022-01-01
- 使用 PDO 转义列名 2021-01-01
- 在 CakePHP 2.0 中使用 Html Helper 时未定义的变量 2021-01-01
- 如何在 Symfony 和 Doctrine 中实现多对多和一对多? 2022-01-01
- 找不到类“AppHttpControllersDB",我也无法使用新模型 2022-01-01
- 如何在 XAMPP 上启用 mysqli? 2021-01-01
- HTTP 与 FTP 上传 2021-01-01
- phpmyadmin 错误“#1062 - 密钥 1 的重复条目‘1’" 2022-01-01
- Doctrine 2 - 在多对多关系中记录更改 2022-01-01
- 在 yii2 中迁移时出现异常“找不到驱动程序" 2022-01-01