Membenihkan Penjana Nombor Rawak dalam JavaScript
Pengenalan:
Penjana nombor rawak terbina dalam JavaScript, Math.random(), tidak boleh disemai atau dimanipulasi secara eksplisit. Walau bagaimanapun, fungsi luaran boleh digunakan untuk menyediakan kefungsian pembenihan dan menjana nombor rawak berkualiti tinggi dengan keadaan awal yang khusus.
Jawapan:
Walaupun Math.random() kekal tidak boleh dibiji, beberapa fungsi Pseudorandom Number Generator (PRNG) yang cekap dan mantap wujud dalam JavaScript yang boleh disemai dan memberikan yang sangat baik rawak.
Permulaan Benih:
Untuk memulakan PRNG dengan betul, adalah penting untuk menggunakan benih entropi tinggi. Satu kaedah yang berkesan ialah menggunakan fungsi cincang seperti cyrb128, yang boleh menjana nilai cincang 128-bit yang pelbagai daripada rentetan input. Sebagai alternatif, mengalas benih dengan data tiruan dan memajukan penjana juga boleh digunakan, walaupun ia mengehadkan bilangan keadaan awal.
sfc32 (Simple Fast Counter) PRNG:
sfc32 ialah PRNG terkenal yang telah berjaya melepasi suite ujian nombor rawak PractRand. Ia beroperasi dengan keadaan 128-bit dan memberikan kelajuan luar biasa dalam JavaScript. Contoh penggunaan sfc32 dengan penjana benih tersuai:
function sfc32(a, b, c, d) { return function() { a |= 0; b |= 0; c |= 0; d |= 0; let t = (a + b | 0) + d | 0; d = d + 1 | 0; a = b ^ b >>> 9; b = c + (c << 3) | 0; c = (c << 21 | c >>> 11); c = c + t | 0; return (t >>> 0) / 4294967296; } } const seedgen = () => (Math.random() * 2 ** 32) >>> 0; const getRand = sfc32(seedgen(), seedgen(), seedgen(), seedgen()); for (let i = 0; i < 10; i++) console.log(getRand());
Menggunakan teknik ini, pembangun JavaScript boleh memanfaatkan kuasa PRNG boleh benih untuk menjana nombor rawak berkualiti tinggi untuk pelbagai aplikasi, daripada simulasi hingga pembangunan permainan .
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Membenihkan Penjana Nombor Rawak dalam JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!