(PHP 4, PHP 5, PHP 7, PHP 8)
rand â Erzeugt eine zufĂ€llige Zahl
Gibt eine Pseudozufallszahl zwischen min und
max (inklusive) zurĂŒck oder zwischen 0 und
getrandmax(), falls keine Parameter angegeben wurden.
Wenn z. B. ein Zufallswert zwischen 5 und 15 benötigt wird, so wÀre der
Aufruf dafĂŒr rand(5, 15).
Diese Funktion erzeugt keine kryptografisch sicheren Werte und darf nicht fĂŒr kryptografische Zwecke verwendet werden oder fĂŒr Zwecke, bei denen die zurĂŒckgegebenen Werte nicht abschĂ€tzbar sein dĂŒrfen.
Falls kryptographisch sichere Zufallszahlen benötigt werden, kann der Random\Randomizer mit der Random\Engine\Secure-Engine verwendet werden. FĂŒr einfache AnwendungsfĂ€lle bieten die Funktionen random_int() und random_bytes() eine bequeme und sichere API, die den CSPRNG des Betriebssystems verwendet.
This function uses the global Mt19937 (âMersenne Twisterâ) instance as the source of randomness and thus shares its state with all other functions using the global Mt19937. Using any of these functions advances the sequence for all the other functions, regardless of scope.
Generating repeatable sequences by seeding mt_srand() or srand() with a known value will also yield repeatable output from this function.
Prefer using Random\Randomizer methods in all newly written code.
Hinweis: Vor PHP 7.1.0 war getrandmax() auf manchen Plattformen (z. B. Windows) nur 32767. Wenn ein gröĂerer Wertebereich benötigt wird, kann entweder ein gröĂerer
max-Wert ĂŒbergeben werden oder es kann stattdessen die Funktion mt_rand() verwendet werden.
Hinweis: Ab PHP 7.1.0 verwendet rand() denselben Zufallszahlengenerator wie mt_rand(). Um die AbwÀrtskompatibilitÀt zu wahren, erlaubt rand(), dass
maxkleiner alsminist, ohne wie mt_rand()falsezurĂŒckzugeben.
minDer niedrigste zurĂŒckzugebende Wert (Vorgabe: 0)
maxDer höchste zurĂŒckzugebende Wert (Vorgabe: getrandmax())
Ein Pseudozufallswert zwischen min (oder 0) und
max (oder getrandmax(),
inklusive).
| Version | Beschreibung |
|---|---|
| 7.2.0 | rand() erhielt einen Bugfix fĂŒr einen Modulus-Verzerrungsfehler. Das bedeutet, dass sich Folgen mit einem bestimmten Startwert ab PHP 7.1 auf 64bit-Rechnern unterscheiden können. |
| 7.1.0 | rand() ist nun ein Alias von mt_rand(). |
Beispiel #1 rand()-Beispiel
<?php
echo rand(), "\n";
echo rand(), "\n";
echo rand(5, 15), "\n";
?>Das oben gezeigte Beispiel erzeugt eine Àhnliche Ausgabe wie:
7771 22264 11
Der Bereich zwischen min und
max muss innerhalb von
getrandmax() liegen, d. h.
abs(max - min) <=
getrandmax().
ansonsten wird rand() möglicherweise Zufallszahlen
schlechter QualitĂ€t zurĂŒckgeben.