php生成随机数方法,PHP生成随机数的方法总结

本文介绍了PHP中几种生成随机数和随机字符串的方法,包括mt_rand(), md5(time()), str_shuffle()等,并通过性能测试对比了mt_rand()与内置函数lcg_value()的效率。此外,还展示了如何使用这些随机数生成工具在图像中创建随机像素效果。
摘要由CSDN通过智能技术生成

第一种方法用mt_rand():

functionGetRandStr($length){

$str='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';

$len=strlen($str)-1;

$randstr='';

for($i=0;$i

$num=mt_rand(0,$len);

$randstr.=$str[$num];

}

return$randstr;

}

$number=GetRandStr(6);

echo$number;

第二种方法(最快的):

functionmake_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 个数组元素连接成字符串

$password.=$chars[$keys[$i]];

} //phpfensi.com

return$password;

}

第三种取当时时间戳:

functionget_password($length= 8 )

{

$str=substr(md5(time()), 0,$length);//md5加密,time()当前时间戳

return$str;

}

第四种打乱字符串:

functiongetrandstr(){

$str='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890';

$randStr=str_shuffle($str);//打乱字符串

$rands=substr($randStr,0,6);//substr(string,start,length);返回字符串的一部分

return$rands;

}

开始创建验证码(直接用函数生成,比较方便快捷)

$code = rand(10000, 99999);

php mt_rand生成0~1随机小数的效果比较

lcg_value说明

float lcg_value ( void )

lcg_value() 返回范围为 (0, 1) 的一个伪随机数。本函数组合了周期为 2^31 – 85 和 2^31 – 249 的两个同余发生器。本函数的周期等于这两个素数的乘积。

返回:范围为 (0, 1) 的伪随机数。

for($i=0;$i<5;$i++){

echolcg_value().PHP_EOL;

}

?>

输出:

0.11516515851995

0.064684551575297

0.68275174031189

0.55730746529099

0.70215008878091

两种生成0~1随机小数方法进行比较

1.执行时间比较

执行10万次基于mt_rand()与mt_getrandmax()算法的运行时间.

/**

* 生成0~1随机小数

* @param Int $min

* @param Int $max

* @return Float

*/

functionrandFloat($min=0,$max=1){

return$min+ mt_rand()/mt_getrandmax() * ($max–$min);

}

// 获取microtime

functionget_microtime(){

list($usec,$sec) =explode(' ', microtime());

return(float)$usec+ (float)$sec;

}

// 记录开始时间

$starttime= get_microtime();

// 执行10万次获取随机小数

for($i=0;$i<100000;$i++){

randFloat();

} //phpfensi.com

// 记录结束时间

$endtime= get_microtime();

// 输出运行时间

printf("run time %f ms\r\n", ($endtime–$starttime)*1000);

?>

输出:run time 266.893148 ms

执行10万次lcg_value()的运行时间

// 获取microtime

functionget_microtime(){

list($usec,$sec) =explode(' ', microtime());

return(float)$usec+ (float)$sec;

}

// 记录开始时间

$starttime= get_microtime();

// 执行10万次获取随机小数

for($i=0;$i<100000;$i++){

lcg_value();

}

// 记录结束时间

$endtime= get_microtime();

// 输出运行时间

printf("run time %f ms\r\n", ($endtime–$starttime)*1000);

?>

输出:run time 86.178064 ms

执行时间上比较,因为lcg_value()直接是php原生方法,而mt_rand()与mt_getrandmax()需要调用两个方法,并需要进行计算,因此lcg_value()的执行时间大约快3倍。

2.随机效果比较

基于mt_rand()与mt_getrandmax()算法的随机效果

/**

* 生成0~1随机小数

* @param Int $min

* @param Int $max

* @return Float

*/

functionrandFloat($min=0,$max=1){

return$min+ mt_rand()/mt_getrandmax() * ($max–$min);

}

header('content-type: image/png');

$im= imagecreatetruecolor(512, 512);

$color1= imagecolorallocate($im, 255, 255, 255);

$color2= imagecolorallocate($im, 0, 0, 0);

for($y=0;$y<512;$y++){

for($x=0;$x<512;$x++){

$rand= randFloat();

if(round($rand,2)>=0.5){

imagesetpixel($im,$x,$y,$color1);

}else{

imagesetpixel($im,$x,$y,$color2);

}

}

}

imagepng($im);

imagedestroy($im);

?>

lcg_value()的随机效果

header('content-type: image/png');

$im= imagecreatetruecolor(512, 512);

$color1= imagecolorallocate($im, 255, 255, 255);

$color2= imagecolorallocate($im, 0, 0, 0);

for($y=0;$y<512;$y++){

for($x=0;$x<512;$x++){

$rand= lcg_value();

if(round($rand,2)>=0.5){

imagesetpixel($im,$x,$y,$color1);

}else{

imagesetpixel($im,$x,$y,$color2);

}

}

}

imagepng($im);

imagedestroy($im);

?>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值