这个没啥好分析的,主要是记录一下,我们直奔主题。
首先想到的是rand(min,max)函数产生随机数,实际上使用mt_rand(min,max)能更加迅速的产生随机数。
其次使用array_unique(arr)对生成的数组进行去重,实际上使用array_flip(array_flip(arr))能更加快速的进行去重。
了解以上两点我们便可以写一个稍微优化过的函数:
/**
* 生成指定长度不重复的字符串.
*
* @param integer $min 最小值.
* @param integer $max 最大值.
* @param integer $len 生成数组长度.
*
* @return array
*/
function uniqueRandom($min, $max, $len)
{
if ($min < 0 || $max < 0 || $len) {
throw new LogicException('无效的参数');
}
if ($max <= $min) {
throw new LogicException('大小传入错误');
}
$counter = 0;
$result = array();
while ($counter < $len) {
$result[] = mt_rand($min, $max);
$result = array_flip(array_flip($result));
$counter = count($result);
}
shuffle($result);
return $result;
}
其实可以利用索引来更加快速的生成不重复的随机数,且效率甩上