這篇文章主要給大家介紹了利用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中文網其他相關文章!