问题
In C++11 one can generate numbers with the use of std::random_device with or without a pseudo random number generator like mt19937.
What will be the difference using this in this exemplar code:
#include <random>
#include <iostream>
int main() {
    std::random_device rd;
    std::mt19937 mt(rd());
    std::uniform_real_distribution<double> dist(1, 10);
    for (int i=0; i<16; ++i)
        std::cout << dist(rd) << "\t" << dist(mt) << "\n";
}
回答1:
std::random_device is supposed to get you a seed for engines like mt19937. The quality of successive numbers produced is completely undefined and may easily be insufficient for practical purposes (such as cryptography), so relying on that is out of question. 
Apart from that, mt19937 will give you the same sequence when given the same seed. A random_devices values can be only influenced by the string given to its constructor... which implies implementation-defined behavior.
回答2:
There are two differences that I know of:
- Using mt199937will be faster but less cryptographically secure.
- std::random_devicewill always be random, but if you initialize your- mt19937with a constant seed it will always give you the same random numbers:- std::mt19937 mt(2014);
Will give the same sequence of random bits every time. This can be useful if you want to test a specific behavior over and over again. The standard requires this in 26.5.5/4:
Required behavior: The 10000th consecutive invocation of a default-constructed object of type
mt19937shall produce the value 4123659995.
There is no such equivalent consistency with std::random_device.
来源:https://stackoverflow.com/questions/26961789/what-is-the-difference-between-using-stdrandom-device-with-prng-e-g-stdmt19