이 기사에서는 주로 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!