rand

(PHP 4, PHP 5, PHP 7, PHP 8)

randГенерирует случайное число

Описание

rand(): int
rand(int $min, int $max): int

Функция rand() возвращает псевдослучайное целое число в диапазоне от 0 до значения функции getrandmax(), если функцию вызвали без параметров min и max. Когда требуется случайное число между 5 и 15 включительно, вызывают rand(5, 15).

Предостережение

Функция не создаёт безопасные для криптографических целей значения, её нельзя использовать в криптографических целях или целях, которые требуют, чтобы значения возврата нельзя было угадать.

Безопасные для криптографических целей случайные последовательности создаёт композиция класса Random\Randomizer с движком Random\Engine\Secure. В простых сценариях пользуются функциями random_int() и random_bytes() с удобным и безопасным API-интерфейсом, который поддерживается безопасным для криптографических целей CSPRNG-генератором псевдослучайных чисел операционной системы.

Замечание: На отдельных платформах, например ОС Windows, функция getrandmax() возвращает максимальное целое число, значение которого не превышает 32 767. Если нужно число из диапазона больше, чем 32 767, указывают параметры min и max, которые разрешат создать число из большего диапазона, или вместо этой функции вызывают функцию mt_rand().

Замечание: Начиная с PHP 7.1.0 функция rand() использует тот же алгоритм генерации случайных чисел, что и функция mt_rand(). Чтобы сохранить обратную совместимость, функция rand() разрешает задавать для параметра max значение меньше, чем значение параметра min, и в отличие от функции mt_rand() не возвращает false.

Список параметров

min

Наименьшее возвращаемое значение. По умолчанию: 0.

max

Наибольшее возвращаемое значение. По умолчанию: значение функции getrandmax().

Возвращаемые значения

Функция возвращает псевдослучайное значение в диапазоне от min (или 0) до max (или значение функции getrandmax()).

Список изменений

Версия Описание
7.2.0 В функции rand() исправили ошибку смещения по модулю. То есть последовательности, которые сгенерировали с конкретным начальным значением, могут несовпадать со значениями, которые сгенерировали в PHP 7.1 на 64-битных машинах.
7.1.0 Функция rand() стала синонимом функции mt_rand().

Примеры

Пример #1 Пример использования функции rand()

<?php

echo rand(), "\n";
echo
rand(), "\n";

echo
rand(5, 15), "\n";

?>

Вывод приведённого примера будет похож на:

7771
22264
11

Примечания

Внимание

Диапазон minmax не должен выходить за границы значения функции getrandmax(). То есть (maxmin) <= getrandmax(). В противном случае функция rand() может возвращать менее качественные случайные числа.

Смотрите также

  • srand() - Задаёт начальное число генератора псевдослучайных чисел
  • getrandmax() - Возвращает максимально возможное случайное число
  • mt_rand() - Генерирует случайное значение через генератор случайных чисел на базе Вихря Мерсенна
  • random_int() - Получает криптографически безопасное равномерно выбранное целое число
  • random_bytes() - Получает криптографически безопасные случайные байты

add a note

User Contributed Notes 1 note

up
3
relsqui at armory dot com
19 years ago
Don't forget, it's faster to use bitwise operations when you need a random number that's less than some power of two. For example,

<?php
rand
()&1;
// instead of
rand(0,1);
// for generating 0 or 1,

rand()&3;
// instead of
rand(0,3);
// for generating 0, 1, 2, or 3,

rand()&7;
// instead of
rand(0,7)
// for generating 0, 1, 2, 3, 4, 5, 6, or 7,
?>

and so on. All you're doing there is generating a default random number (so PHP doesn't have to parse any arguments) and chopping off the piece that's useful to you (using a bitwise operation which is faster than even basic math).
To Top