array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'uk', ), 'this' => array ( 0 => 'function.srand.php', 1 => 'srand', 2 => 'Seed the random number generator', ), 'up' => array ( 0 => 'ref.random.php', 1 => 'Random Функції', ), 'prev' => array ( 0 => 'function.random-int.php', 1 => 'random_int', ), 'next' => array ( 0 => 'class.random-randomizer.php', 1 => 'Random\\Randomizer', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'en', 'path' => 'reference/random/functions/srand.xml', ), 'history' => array ( ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); contributors($setup); ?>
(PHP 4, PHP 5, PHP 7, PHP 8)
srand — Seed the random number generator
Seeds the random number generator with
seed or with a random value
if no seed is given.
Зауваження: Не потрібно ініціалізазувати генератор випадкових чисел функціями srand() або mt_srand(), оскільки це відбувається автоматично.
Оскільки рушій Mt19937 (“Mersenne Twister”) приймає тільки одне 32-бітне ціле число як сід, кількість можливих випадкових послідовностей обмежена до лише 232 (тобто 4ʼ294ʼ967ʼ296), не зважаючи на величезний період Mt19937 у 219937-1.
Якщо покладатися на неявний чи явний випадковий сід, дуплікати зʼявляться набагато швидше. Однакові сіди очікуються з імовірністю у 50% менше ніж через 80ʼ000 випадково згенерованих сідів, відповідно до парадоксу днів народжень. Імовірність у 10% настає після 30ʼ000 сідів, згенерованих випадковим чином.
Через це Mt19937 непридатний для застосунків, де повторювані послідовності не повинні виникати з більш ніж незначною ймовірністю. Якщо потрібне відтворюване сідування, обидва рушії Random\Engine\Xoshiro256StarStar і Random\Engine\PcgOneseq128XslRr64 підтримують набагато довші сіди, які навряд випадково співпадуть. Якщо відтворюваність не потрібна, то для цього є рушій Random\Engine\Secure, який надає криптографічно безпечну випадковість.
Зауваження: As of PHP 7.1.0, srand() has been made an alias of mt_srand().
seed
Fills the state with values generated with a linear congruential generator
that was seeded with seed interpreted as an unsigned
32 bit integer.
If seed is omitted or null, a random unsigned
32-bit integer will be used.
Не повертає значень.
| Версія | Опис |
|---|---|
| 8.3.0 |
seed is now nullable.
|
| 7.1.0 | srand() has been made an alias of mt_srand(). |