Udostępnij za pośrednictwem


rand_s

Generuje liczby pseudolosowe.Wersja z RAND z rozszerzeń zabezpieczeń opisane w Funkcje zabezpieczeń w CRT.

errno_t rand_s(   unsigned int* randomValue);

Wartość zwracana

Zero, jeśli kończy się pomyślnie, w przeciwnym razie kod błędu.Jeśli wskaźnik wprowadzania randomValue jest wskaźnik null, funkcja wywołuje funkcję obsługi nieprawidłowy parametr, jak opisano w Sprawdzanie poprawności parametru.Jeśli wykonanie mogą w dalszym ciągu, funkcja zwraca EINVAL i ustawia errno do EINVAL.Jeśli funkcja zakończy się niepowodzeniem z innego powodu, *randomValue jest ustawiona na 0.

Uwagi

rand_s Funkcja zapisuje pseudolosowe liczbą całkowitą z zakresu od 0 do UINT_MAX do wprowadzania wskaźnik.rand_s Funkcja używa systemu operacyjnego dla generatora liczb losowych kryptograficznie bezpieczne.Nie używa materiału siewnego generowanych przez srand — inicjuje funkcji, ani nie wpływa on na losowe sekwencji numerów używanych przez rand.

rand_s Funkcja wymaga tej stałej _CRT_RAND_S określony przed instrukcji włączenia funkcji, które mają zostać zadeklarowane, jak w poniższym przykładzie:

#define _CRT_RAND_S
#include <stdlib.h>

rand_szależy od RtlGenRandom interfejsu API, który jest tylko dostępna w systemie Windows XP i nowszych.

Wymagania

Rozpoczęto wykonywanie procedury

Wymaganego nagłówka

rand_s

<stdlib.h>

Aby uzyskać więcej informacji, zobacz zgodności.

Przykład

// crt_rand_s.c
// This program illustrates how to generate random
// integer or floating point numbers in a specified range.

// Remembering to define _CRT_RAND_S prior
// to inclusion statement.
#define _CRT_RAND_S

#include <stdlib.h>
#include <stdio.h>
#include <limits.h>

int main( void )
{
    int             i;
    unsigned int    number;
    double          max = 100.0;
    errno_t         err;

    // Display 10 random integers in the range [ 1,10 ].
    for( i = 0; i < 10;i++ )
    {
        err = rand_s( &number );
        if (err != 0)
        {
            printf_s("The rand_s function failed!\n");
        }
        printf_s( "  %u\n", (unsigned int) ((double)number /
                       ((double) UINT_MAX + 1 ) * 10.0) + 1);
    }

    printf_s("\n");

    // Display 10 random doubles in [0, max).
    for (i = 0; i < 10;i++ )
    {
        err = rand_s( &number );
        if (err != 0)
        {
            printf_s("The rand_s function failed!\n");
        }
        printf_s( "  %g\n", (double) number / 
                          ((double) UINT_MAX + 1) * max );
    }
}

Przykładowe dane wyjściowe

  10
  4
  5
  2
  8
  2
  5
  6
  1
  1

  32.6617
  29.4471
  11.5413
  6.41924
  20.711
  60.2878
  61.0094
  20.1222
  80.9192
  65.0712

Odpowiednik w programie .NET Framework

Klasa System::Random

Zobacz też

Informacje

Wsparcie zmiennoprzecinkowe

srand — inicjuje