array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'fr', ), 'this' => array ( 0 => 'function.srand.php', 1 => 'srand', ), 'up' => array ( 0 => 'ref.random.php', 1 => 'Random Fonctions', ), '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' => 'fr', 'path' => 'reference/random/functions/srand.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 4, PHP 5, PHP 7, PHP 8)
srand — Initialise le générateur de nombres aléatoires
srand() initialise le générateur de
nombres aléatoires avec seed
,
ou avec une valeur aléatoire si seed
est
0
.
Note: Il n'est pas nécessaire d'initialiser le générateur de nombres aléatoires avec srand() ou mt_srand(), ceci est fait automatiquement.
Étant donné que le moteur Mt19937 ("Mersenne Twister") prend un seul entier de 32 bits en tant que graine, le nombre de séquences aléatoires possibles est limité à seulement 232 (par exemple 4 294 967 296), malgré la période énorme de Mt19937 de 219937-1.
Quand on se fie à une graine aléatoire implicite ou explicite, les duplications apparaîtront beaucoup plus tôt. Les graines dupliquées sont attendues avec une probabilité de 50% après moins de 80 000 graines générées aléatoirement selon le problème d anniversaire. Une probabilité de 10% d une graine dupliquée se produit après avoir généré environ 30 000 graines de manière aléatoire.
Cela rend Mt19937 inadapté aux applications où les séquences dupliquées ne doivent pas se produire avec plus qu une probabilité négligeable. Si une graine reproductible est requise, à la fois le moteur Random\Engine\Xoshiro256StarStar et Random\Engine\PcgOneseq128XslRr64 supportent des graines beaucoup plus grandes qui sont peu susceptibles de se heurter de manière aléatoire. Si la reproductibilité n'est pas requise, le moteur Random\Engine\Secure fournit des données aléatoires cryptographiquement sécurisées.
Note: Depuis PHP 7.1.0, srand() est un alias de mt_srand().
seed
Remplit l'état avec des valeurs générées par un générateur congruentiel linéaire
qui a été initialisé avec seed
interprété comme un entier non signé
de 32 bits.
Si seed
est omis ou null
, un entier non signé
de 32 bits sera utilisé de manière aléatoire.
Aucune valeur n'est retournée.
Version | Description |
---|---|
8.3.0 |
seed est désormais nullable.
|
7.1.0 | srand() est devenu un alias de mt_srand(). |