Maison >développement back-end >C++ >Comment puis-je générer des graines entièrement aléatoires pour mt19937 en C ?
Problème :
Les réponses récentes suggèrent souvent d'utiliser
Ensemencement portable et approfondi :
Une approche portable et approfondie de l'ensemencement de mt19937 implique l'utilisation d'un CSPRNG, tel comme :
Exemple de code :
#include <cstdint> #include <cstdlib> #include <fstream> size_t sysrandom(void* dst, size_t dstlen); std::uint_least32_t seed; sysrandom(&seed, sizeof(seed)); std::mt19937 gen(seed);
Linux Spécialisation avec getrandom :
#if defined(HAVE_GETRANDOM) size_t sysrandom(void* dst, size_t dstlen) { int bytes = syscall(SYS_getrandom, dst, dstlen, 0); if (bytes != dstlen) { throw std::runtime_error("Unable to read N bytes from CSPRNG."); } return dstlen; } #endif
Cas spécial OpenBSD :
#if defined(HAVE_GETENTROPY) size_t sysrandom(void* dst, size_t dstlen) { int bytes = getentropy(dst, dstlen); if (bytes != dstlen) { throw std::runtime_error("Unable to read N bytes from CSPRNG."); } return dstlen; } #endif
Autres réflexions :
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!