Condividi tramite


rand

Genera un numero pseudocasuale. È disponibile una versione più sicura a livello di codice di questa funzione; vedere rand_s. I numeri generati da rand non sono crittograficamente sicuri. Per una generazione di numeri casuali più sicura in modo crittografico, usare rand_s o le funzioni dichiarate nella libreria standard C++ in <random>.

Sintassi

int rand(void);

Valore restituito

rand restituisce un numero pseudocasuale, come descritto in precedenza. Non viene restituito alcun errore.

Osservazioni:

La funzione rand restituisce un Integer pseudocasuale nell'intervallo compreso tra 0 e RAND_MAX (32767). Usare la srand funzione per inizializzare il generatore di numeri pseudorandoma prima di chiamare rand.

La rand funzione genera una sequenza nota e non è appropriata per l'uso come funzione crittografica. Per una generazione di numeri casuali più sicura in modo crittografico, usare rand_s o le funzioni dichiarate nella libreria standard C++ in <random>.

Per impostazione predefinita, lo stato globale di questa funzione è limitato all'applicazione. Per modificare questo comportamento, vedere Stato globale in CRT.

Requisiti

Ciclo Intestazione obbligatoria
rand <stdlib.h>

Per altre informazioni sulla compatibilità, vedere Compatibility (Compatibilità).

Esempio

// crt_rand.c
// This program seeds the random-number generator
// with a fixed seed, then exercises the rand function
// to demonstrate generating random numbers, and
// random numbers in a specified range.

#include <stdlib.h> // rand(), srand()
#include <stdio.h> // printf()

void SimpleRandDemo(int n)
{
    // Print n random numbers.
    for (int i = 0; i < n; i++)
    {
        printf("  %6d\n", rand());
    }
}

void RangedRandDemo(int range_min, int range_max, int n)
{
    // Generate random numbers in the interval [range_min, range_max], inclusive.

    for (int i = 0; i < n; i++)
    {
        // Note: This method of generating random numbers in a range isn't suitable for
        // applications that require high quality random numbers.
        // rand() has a small output range [0,32767], making it unsuitable for
        // generating random numbers across a large range using the method below.
        // The approach below also may result in a non-uniform distribution.
        // More robust random number functionality is available in the C++ <random> header.
        // See https://zcusa.951200.xyz/cpp/standard-library/random
        int r = ((double)rand() / RAND_MAX) * (range_max - range_min) + range_min;
        printf("  %6d\n", r);
    }
}

int main(void)
{
    // Seed the random-number generator with a fixed seed so that
    // the numbers will be the same every time we run.
    srand(1792);

    printf("Simple random number demo ====\n\n");
    SimpleRandDemo(10);
    printf("\nRandom number in a range demo ====\n\n");
    RangedRandDemo(-100, 100, 100000);
}```

```Output
Simple random number demo ====

    5890
    1279
   19497
    1207
   11420
    3377
   15317
   29489
    9716
   23323

Random number in a range demo ====

     -82
     -46
      50
      77
     -47
      32
      76
     -13
     -58
      90

Vedi anche

Supporto matematico e a virgola mobile
srand
rand_s
Libreria C++ <random>