PHP中函數(shù)rand和mt_rand的區(qū)別比較
更新時間:2012年12月26日 23:23:51 作者:
mt_rand() 比rand() 快四倍,很多老的 libc 的隨機數(shù)發(fā)生器具有一些不確定和未知的特性而且很慢。PHP 的 rand() 函數(shù)默認使用 libc 隨機數(shù)發(fā)生器。mt_rand() 函數(shù)是非正式用來替換它的。
PHP函數(shù)rand和mt_rand
mt_rand() 比rand() 快四倍
很多老的 libc 的隨機數(shù)發(fā)生器具有一些不確定和未知的特性而且很慢。PHP 的 rand() 函數(shù)默認使用 libc 隨機數(shù)發(fā)生器。mt_rand() 函數(shù)是非正式用來替換它的。該函數(shù)用了 Mersenne Twister 中已知的特性作為隨機數(shù)發(fā)生器,mt_rand() 可以產生隨機數(shù)值的平均速度比 libc 提供的 rand() 快四倍。
mt_rand() 比rand() 快四倍
mt_rand — 生成更好的隨機數(shù)
(PHP 3 >= 3.0.6, PHP 4, PHP 5)
int mt_rand ( [int min, int max] )
很多老的 libc 的隨機數(shù)發(fā)生器具有一些不確定和未知的特性而且很慢。PHP 的 rand() 函數(shù)默認使用 libc 隨機數(shù)發(fā)生器。mt_rand() 函數(shù)是非正式用來替換它的。該函數(shù)用了 Mersenne Twister(馬其塞旋轉) 中已知的特性作為隨機數(shù)發(fā)生器,它可以產生隨機數(shù)值的平均速度比 libc 提供的 rand() 快四倍。
如果沒有提供可選參數(shù) min 和 max,mt_rand() 返回
0 到 RAND_MAX 之間的偽隨機數(shù)。
例如想要 5 到 15(包括 5 和 15)之間的隨機數(shù),用 mt_rand(5, 15)。
注: 自 PHP 4.2.0 起,不再需要用 srand() 或 mt_srand() 函數(shù)給隨機數(shù)生成器播種,現(xiàn)已自動完成。
rand — 產生一個隨機整數(shù)
(PHP 3, PHP 4, PHP 5)
int rand ( [int min, int max] )
如果沒有提供可選參數(shù) min 和 max,rand() 返回 0 到 RAND_MAX 之間的偽隨機整數(shù)。例如想要 5 到 15(包括 5 和 15)之間的隨機數(shù),用 rand(5, 15)。
注: 在某些平臺下(例如 Windows)RAND_MAX 只有 32768。如果需要的范圍大于 32768,那么指定 min 和 max 參數(shù)就可以生成大于 RAND_MAX的數(shù)了,或者考慮用 mt_rand() 來替代之。
注: 自 PHP 4.2.0 起,不再需要用 srand() 或 mt_srand() 函數(shù)給隨機數(shù)生成器播種,現(xiàn)已自動完成。
mt_rand定義和用法
mt_rand() 使用 Mersenne Twister 算法返回隨機整數(shù)。
語法
mt_rand(min,max)說明
如果沒有提供可選參數(shù) min 和 max,mt_rand() 返回 0 到 RAND_MAX 之間的偽隨機數(shù)。例如想要 5 到 15(包括 5 和 15)之間的隨機數(shù),用 mt_rand(5, 15)。
很多老的 libc 的隨機數(shù)發(fā)生器具有一些不確定和未知的特性而且很慢。PHP 的 rand() 函數(shù)默認使用 libc 隨機數(shù)發(fā)生器。mt_rand() 函數(shù)是非正式用來替換它的。該函數(shù)用了 Mersenne Twister 中已知的特性作為隨機數(shù)發(fā)生器,它可以產生隨機數(shù)值的平均速度比 libc 提供的 rand() 快四倍。
提示和注釋
注釋:自 PHP 4.2.0 起,不再需要用 srand() 或 mt_srand() 函數(shù)給隨機數(shù)發(fā)生器播種,現(xiàn)在已自動完成。
注釋:在 3.0.7 之前的版本中,max 的含義是 range 。要在這些版本中得到和上例相同 5 到 15 的隨機數(shù),簡短的例子是 mt_rand (5, 11)。
例子
在本例中,我們會返回一些隨機數(shù):
<?php
echo(mt_rand());
echo(mt_rand());
echo(mt_rand(10,100));
?>
輸出類似:
3150906288
513289678
35
mt_rand() 比rand() 快四倍
很多老的 libc 的隨機數(shù)發(fā)生器具有一些不確定和未知的特性而且很慢。PHP 的 rand() 函數(shù)默認使用 libc 隨機數(shù)發(fā)生器。mt_rand() 函數(shù)是非正式用來替換它的。該函數(shù)用了 Mersenne Twister 中已知的特性作為隨機數(shù)發(fā)生器,mt_rand() 可以產生隨機數(shù)值的平均速度比 libc 提供的 rand() 快四倍。
mt_rand() 比rand() 快四倍
mt_rand — 生成更好的隨機數(shù)
(PHP 3 >= 3.0.6, PHP 4, PHP 5)
int mt_rand ( [int min, int max] )
很多老的 libc 的隨機數(shù)發(fā)生器具有一些不確定和未知的特性而且很慢。PHP 的 rand() 函數(shù)默認使用 libc 隨機數(shù)發(fā)生器。mt_rand() 函數(shù)是非正式用來替換它的。該函數(shù)用了 Mersenne Twister(馬其塞旋轉) 中已知的特性作為隨機數(shù)發(fā)生器,它可以產生隨機數(shù)值的平均速度比 libc 提供的 rand() 快四倍。
如果沒有提供可選參數(shù) min 和 max,mt_rand() 返回
0 到 RAND_MAX 之間的偽隨機數(shù)。
例如想要 5 到 15(包括 5 和 15)之間的隨機數(shù),用 mt_rand(5, 15)。
注: 自 PHP 4.2.0 起,不再需要用 srand() 或 mt_srand() 函數(shù)給隨機數(shù)生成器播種,現(xiàn)已自動完成。
rand — 產生一個隨機整數(shù)
(PHP 3, PHP 4, PHP 5)
int rand ( [int min, int max] )
如果沒有提供可選參數(shù) min 和 max,rand() 返回 0 到 RAND_MAX 之間的偽隨機整數(shù)。例如想要 5 到 15(包括 5 和 15)之間的隨機數(shù),用 rand(5, 15)。
注: 在某些平臺下(例如 Windows)RAND_MAX 只有 32768。如果需要的范圍大于 32768,那么指定 min 和 max 參數(shù)就可以生成大于 RAND_MAX的數(shù)了,或者考慮用 mt_rand() 來替代之。
注: 自 PHP 4.2.0 起,不再需要用 srand() 或 mt_srand() 函數(shù)給隨機數(shù)生成器播種,現(xiàn)已自動完成。
mt_rand定義和用法
mt_rand() 使用 Mersenne Twister 算法返回隨機整數(shù)。
語法
mt_rand(min,max)說明
如果沒有提供可選參數(shù) min 和 max,mt_rand() 返回 0 到 RAND_MAX 之間的偽隨機數(shù)。例如想要 5 到 15(包括 5 和 15)之間的隨機數(shù),用 mt_rand(5, 15)。
很多老的 libc 的隨機數(shù)發(fā)生器具有一些不確定和未知的特性而且很慢。PHP 的 rand() 函數(shù)默認使用 libc 隨機數(shù)發(fā)生器。mt_rand() 函數(shù)是非正式用來替換它的。該函數(shù)用了 Mersenne Twister 中已知的特性作為隨機數(shù)發(fā)生器,它可以產生隨機數(shù)值的平均速度比 libc 提供的 rand() 快四倍。
提示和注釋
注釋:自 PHP 4.2.0 起,不再需要用 srand() 或 mt_srand() 函數(shù)給隨機數(shù)發(fā)生器播種,現(xiàn)在已自動完成。
注釋:在 3.0.7 之前的版本中,max 的含義是 range 。要在這些版本中得到和上例相同 5 到 15 的隨機數(shù),簡短的例子是 mt_rand (5, 11)。
例子
在本例中,我們會返回一些隨機數(shù):
復制代碼 代碼如下:
<?php
echo(mt_rand());
echo(mt_rand());
echo(mt_rand(10,100));
?>
輸出類似:
3150906288
513289678
35
相關文章
PHP+Ajax實現(xiàn)的無刷新分頁功能詳解【附demo源碼下載】
這篇文章主要介紹了PHP+Ajax實現(xiàn)的無刷新分頁功能,結合具體實例形式分析了php+ajax通過pdo操作類讀取數(shù)據庫并分頁顯示的相關實現(xiàn)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-07-07