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 - if 语句中的倒序 2021-01-01
- 覆盖 Magento 社区模块控制器的问题 2022-01-01
- Oracle 即时客户端 DYLD_LIBRARY_PATH 错误 2022-01-01
- PHP foreach() 与数组中的数组? 2022-01-01
- 如何使用 Google API 在团队云端硬盘中创建文件夹? 2022-01-01
- 使用 GD 和 libjpeg 支持编译 PHP 2022-01-01
- Laravel 5:Model.php 中的 MassAssignmentException 2021-01-01
- 如何从数据库中获取数据以在 laravel 中查看页面? 2022-01-01
- 如何在 Symfony2 中正确使用 webSockets 2021-01-01
- openssl_digest vs hash vs hash_hmac?盐与盐的区别HMAC? 2022-01-01