首頁 >後端開發 >php教程 >PHP資料自增情況下產生的隨機數不重複

PHP資料自增情況下產生的隨機數不重複

巴扎黑
巴扎黑原創
2017-08-22 17:47:311809瀏覽

這篇文章主要給大家介紹了利用PHP基於自增數據如何能產生不重複的隨機數,文中給出了詳細的示例代碼供大家參考學習,對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。

本文主要介紹了PHP基於自增資料產生不重複的隨機數的相關內容,分享出來供大家參考學習,下面多說無益直接上代碼:

關鍵點在於產生的自增資料位元控制

位元控制在於兩個地方

#      1、 $base 基底陣列若是8位元這個陣列必須是8位元

      2、 $i 自增數,自增數不能超過8位數

目前簡單分析的結果是以上。大家如果是全域不重複,還是建議使用uuid之類的比較適合。

範例程式碼:


function swap($n,$base) {
$mask = 19; //1 + 2 + 16
 $n = intval($n, 10);
 $idx = $n & $mask;//取出标志位
 $xor = $base[$idx] ^ $n;//根据标识为找到对应的base,异或n
 
 return (($xor | $mask) ^ $mask) | $idx;//覆盖标识位
}
$newArray=[];
$base = array (
 0 => 1918407,
 1 => 5529570,
 2 => 6527234,
 3 => 6550962,
 4 => 8054672,
 5 => 3141234,
 6 => 2125630,
 7 => 6978033,
 8 => 4623630,
 9 => 4736420,
 10 => 7767295,
 11 => 9679880,
 12 => 1665600,
 13 => 6044373,
 14 => 4661383,
 15 => 5771843,
 16 => 2206123,
 17 => 5685396,
 18 => 5571647,
 19 => 7178311,
);
for ($i=0;$i<1000000;$i++) {
 $newArray[]= swap($i,$base)."\r\n";
}

以上是PHP資料自增情況下產生的隨機數不重複的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn