隨機(jī)產(chǎn)生數(shù)字往往應(yīng)用在隨機(jī)的密碼或隨機(jī)驗(yàn)證碼之類上面,PHP中有rand()干擾函數(shù)和MD5來實(shí)現(xiàn),下面我們來看一下結(jié)合PHP函數(shù)來產(chǎn)生一組不重復(fù)的數(shù)字?jǐn)?shù)組是如何用程序來實(shí)現(xiàn)的,直接上代碼:
- <?php
- /**
- * PHP獲取一組隨機(jī)數(shù)字不重復(fù)
- */
- $a = microtime();
- function createRandID($m){
- // 產(chǎn)生一個(gè)從1到$m的數(shù)組
- $arr = range(1,$m);
- // 打亂數(shù)組
- shuffle ($arr);
- // 取前十個(gè)
- for($i=0;$i<=10;$i++){
- // 賦值給新數(shù)組$n
- $n[] = $arr[$i];
- }
- // 返回這組數(shù)字
- return implode($n,',');
- }
- echo createRandID(700000);
- echo '<br />';
- echo $a - microtime();
- ?>
執(zhí)行結(jié)果:
由以上結(jié)果可以看到,時(shí)間花了0.6,我們把隨機(jī)數(shù)范圍從700000調(diào)到900000再看看執(zhí)行結(jié)果:Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 7200000 bytes) in /data0/htdocs/www/a.php on line 10
數(shù)組太大程序跑不下了,代碼如下:
- <?php
- /**
- * PHP獲取一組隨機(jī)數(shù)字不重復(fù)
- * PHP博客
- */
- $a = microtime();
- function createRandID($m){
- // 注意,要先聲明一個(gè)空數(shù)組,否則while里的in_array會(huì)報(bào)錯(cuò)
- $arr = array();
- // 使用while循環(huán),只要不夠10個(gè)就永遠(yuǎn)循環(huán)
- while(count($arr)<=10){
- // 產(chǎn)生一個(gè)隨機(jī)數(shù)
- $a = rand(1,$m);
- // 判斷:如果產(chǎn)生的隨機(jī)數(shù)不再數(shù)組里就賦值到數(shù)組里
- // 主要避免產(chǎn)生重復(fù)的數(shù)字
- if(!in_array($a,$arr)){
- // 把隨機(jī)數(shù)賦值到數(shù)組里
- $arr[] = $a;
- }
- }
- // 返回產(chǎn)生的隨機(jī)數(shù)字
- return implode($arr,',');
- }
- echo createRandID(700000);
- echo '<br />';
- echo $a - microtime();
- ?>
執(zhí)行結(jié)果:
308326,155128,280424,493174,214855,219990,482837,66329,512934,232527,3869750.00015699999999996
由以上執(zhí)行結(jié)果可以看到,時(shí)間根本可以忽略不計(jì),我們把隨機(jī)數(shù)范圍從700000調(diào)到999999再看看執(zhí)行結(jié)果
392281,822956,401282,176255,143076,501802,393338,546922,21836,601991,3620060.00013600000000002
執(zhí)行結(jié)果跟最大取數(shù)值設(shè)置都沒有絲毫關(guān)系,還是跑的挺快!
新聞熱點(diǎn)
疑難解答