從一個數組中隨機取出n個值,用array_rand()可以輕易的實現,當面對大數組的時候,我們會擔心他的效率、效能問題。
我測試了一下,當在一個大小為一萬的數組中隨機取出20個值,即array_rand($arr, 20)的時候,程式只花費了0.005s左右,效率非常高。平時基本上都不會遇到這麼大的數組吧,所以我們不必擔心array_rand效率問題了。
同時,我用了另外一種用隨機數的方法。
$arr = array(1,2,3,4,5...9999);
for($i=0; $i<20; $i++)
{
$rands = mt_rand(0,9999);
$aa[] = $arr[$rands];
}
運行程式,也只需要大概0.005s左右。
執行個體、隨機數組
function make_password( $length = 8 )
{
// 密碼字元集,可任意添加你需要的字元
$chars = array('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h',
'i', 'j', 'k', 'l','m', 'n', 'o', 'p', 'q', 'r', 's',
't', 'u', 'v', 'w', 'x', 'y','z', 'A', 'B', 'C', 'D',
'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L','M', 'N', 'O',
'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y','Z',
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '!',
'@','#', '$', '%', '^', '&', '*', '(', ')', '-', '_',
'[', ']', '{', '}', '<', '>', '~', '`', '+', '=', ',',
'.', ';', ':', '/', '?', '|');
// 在 $chars 中隨機取 $length 個數組元素鍵名
$keys = array_rand($chars, $length);
$password = '';
for($i = 0; $i < $length; $i++)
{
// 將 $length 個數組元素串連成字串
$password .= $chars[$keys[$i]];
}
return $password;
}
我猜想,array_rand底層的演算法可能就是以上這種方法做出來的。所以取數組中隨機值,放心大膽的用array_rand吧。