Udostępnij za pośrednictwem


seed_seq — Klasa

Przechowuje wektora wartości Liczba całkowita bez znaku, które może dostarczyć losowy inicjatora dla aparatu liczbę losową.

class seed_seq { public:     // types     typedef unsigned int result_type;     // constructors     seed_seq();     template<class T>     seed_seq(initializer_list<T> initlist);     template<class InputIterator>     seed_seq(InputIterator begin, InputIterator end);     // generating functions     template<class RandomAccessIterator>     void generate(RandomAccessIterator begin, RandomAccessIterator end);     // property functions     size_t size() const;     template<class OutputIterator>     void param(OutputIterator dest) const;     // no-copy functions     seed_seq(const seed_seq&) = delete;     void operator=(const seed_seq&) = delete; };

Elementy członkowskie

Konstruktorów

Podpis

Opis

seed_seq();

Domyślny konstruktor inicjuje pusty sekwencji wewnętrznego.

template<class T>
seed_seq(initializer_list<T> initlist);

Używa initlist można ustawić wewnętrzny sekwencji.

Tmusi być liczbą całkowitą.

template<class InputIterator>
seed_seq(InputIterator begin, InputIterator end);

Inicjuje wewnętrzny sekwencji za pomocą wszystkich elementów z zakresu wejściowego sterująca udostępnione.

iterator_traits<InputIterator>::value_typemusi być liczbą całkowitą.

Generowanie funkcje

Podpis

Opis

template<class RandomAccessIterator>
void generate(RandomAccessIterator begin, 
        RandomAccessIterator end);

Wypełnia elementy podanego sekwencji przy użyciu algorytmu wewnętrznego.Wewnętrzny sekwencji, z którą ma wpływ ten algorytm seed_seq został zainicjowany.

Nie robi nic, jeśli begin == end.

Funkcje właściwości

Podpis

Opis

size_t size() const;

Zwraca liczbę elementów w seed_seq.

template<class OutputIterator>
void param(OutputIterator dest) const;

Kopiuje wewnętrzny sekwencji do sterująca dane wyjściowe dest.

Przykład

Poniższy przykładowy kod wykonuje trzy konstruktory i generuje dane wyjściowe z wynikowy seed_seq wystąpień przypisany do tablicy.Na przykład, który korzysta z seed_seq generator liczb losowych patrz <random>.

#include <iostream>
#include <random>
#include <string>
#include <array>

using namespace std;

void test(const seed_seq& sseq) {
    cout << endl << "seed_seq::size(): " << sseq.size() << endl;
    
    cout << "seed_seq::param(): ";
    ostream_iterator<unsigned int> out(cout, " ");
    sseq.param(out);
    cout << endl;

    cout << "Generating a sequence of 5 elements into an array: " << endl;
    array<unsigned int, 5> seq;
    sseq.generate(seq.begin(), seq.end());
    for (unsigned x : seq) { cout << x << endl; }
}

int main()
{
    seed_seq seed1;
    test(seed1);

    seed_seq seed2 = { 1701, 1729, 1791 };
    test(seed2);

    string sstr = "A B C D"; // seed string
    seed_seq seed3(sstr.begin(), sstr.end());
    test(seed3);
}

Dane wyjściowe

  

Uwagi

Funkcji elementów członkowskich tej klasy nie zgłosi wyjątku wyjątków.

Wymagania

Nagłówek: < losowe >

Przestrzeń nazw: std

Zobacz też

Informacje

<random>