array_rand是數(shù)組隨機(jī)函數(shù)了,我今天看到一個(gè)站長(zhǎng)簡(jiǎn)單的介紹array_rand性能了,于是把許久沒(méi)寫(xiě)的php再來(lái)簡(jiǎn)單的看看,我們一起來(lái)看看array_rand函數(shù)用法吧。
從一個(gè)數(shù)組中隨機(jī)取出n個(gè)值,用array_rand()可以輕易的實(shí)現(xiàn),當(dāng)面對(duì)大數(shù)組的時(shí)候,我們會(huì)擔(dān)心他的效率、性能問(wèn)題。
我測(cè)試了一下,當(dāng)在一個(gè)大小為一萬(wàn)的數(shù)組中隨機(jī)取出20個(gè)值,即array_rand($arr, 20)的時(shí)候,程序只花費(fèi)了0.005s左右,效率非常高。平時(shí)基本上都不會(huì)遇到這么大的數(shù)組吧,所以我們不必?fù)?dān)心array_rand效率問(wèn)題了。
同時(shí),我用了另外一種用隨機(jī)數(shù)的方法。
- $arr = array(1,2,3,4,5...9999);
- for($i=0; $i<20; $i++)
- {
- $rands = mt_rand(0,9999);
- $aa[] = $arr[$rands];
- }
運(yùn)行程序,也只需要大概0.005s左右。
實(shí)例、隨機(jī)數(shù)組
- 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 中隨機(jī)取 $length 個(gè)數(shù)組元素鍵名
- $keys = array_rand($chars, $length);
- $password = '';
- for($i = 0; $i < $length; $i++)
- { //Vevb.com
- // 將 $length 個(gè)數(shù)組元素連接成字符串
- $password .= $chars[$keys[$i]];
- }
- return $password;
- }
我猜想,array_rand底層的算法可能就是以上這種方法做出來(lái)的。所以取數(shù)組中隨機(jī)值,放心大膽的用array_rand吧。
新聞熱點(diǎn)
疑難解答