random(3) Library Functions Manual random(3) NOM random, srandom, initstate, setstate - Generateur de nombres aleatoires BIBLIOTHEQUE Bibliotheque C standard (libc, -lc) SYNOPSIS #include long random(void); void srandom(unsigned int graine); char *initstate(unsigned int graine, char etat, size_t n); char *setstate(char *etat); Exigences de macros de test de fonctionnalites pour la glibc (consulter feature_test_macros(7)) : random(), srandom(), initstate(), setstate(): _XOPEN_SOURCE >= 500 || /* glibc >= 2.19 : */ _DEFAULT_SOURCE || /* glibc <= 2.19 : */ _SVID_SOURCE || _BSD_SOURCE DESCRIPTION La fonction random() utilise un generateur de nombre aleatoire non lineaire (<< non-linear additive feedback random number generator >>) utilisant une table par defaut de 31 entiers longs pour renvoyer successivement des nombres pseudoaleatoires entre 0 et 2^31 - 1. La periode de ce generateur est tres grande, approximativement 16 * ((2^31) - 1). La fonction srandom() utilise son argument comme << graine >> pour engendrer une nouvelle sequence de nombres pseudoaleatoires qui seront fournis lors des appels a random(). Ces sequences sont reproductibles en invoquant srandom() avec la meme graine. Si aucune graine n'est fournie, aa fonction random() utilise automatiquement une graine originale de valeur 1. La fonction initstate() permet d'initialiser une table d'etats state pour l'utiliser avec random(). La taille n de la table est utilisee par initstate() pour determiner le niveau de sophistication du generateur de nombres aleatoires. Plus grande est la table d'etats, meilleurs seront les nombres aleatoires. Les valeurs << optimales >> pour la taille de la table d'etats n sont 8, 32, 64, 128 et 256 octets ; les autres montants seront arrondis au montant connu le plus proche. Utiliser moins de huit octets provoque une erreur. graine est la graine utilise pour l'initialisation, indiquant un point de depart pour la sequence de nombres aleatoires, et permet de redemarrer au meme endroit. La fonction setstate() modifie la table d'etats utilisee par la fonction random(). La table d'etats etat est alors utilise comme generateur de nombres aleatoires jusqu'au prochain appel de initstate() ou setstate(). etat doit d'abord etre initialisee avec initstate() ou etre le resultat d'un appel precedent a setstate(). VALEUR RENVOYEE La fonction random() renvoie une valeur entre 0 et (2^31) - 1. La fonction srandom() ne renvoie pas de valeur. La fonction initstate() renvoie un pointeur sur la table d'etats precedente. En cas d'echec, elle renvoie NULL et errno contient le code d'erreur. La fonction setstate() renvoie un pointeur sur la table d'etats precedente. En cas d'echec, NULL est renvoye et errno est defini pour indiquer l'erreur. ERREURS EINVAL Le parametre etat de setstate() etait NULL. EINVAL Une table d'etats de moins de 8 octets a ete fournie a initstate(). ATTRIBUTS Pour une explication des termes utilises dans cette section, consulter attributes(7). +---------------------------------+--------------------------+---------+ |Interface | Attribut | Valeur | +---------------------------------+--------------------------+---------+ |random(), srandom(), | Securite des threads | MT-Safe | |initstate(), setstate() | | | +---------------------------------+--------------------------+---------+ STANDARDS POSIX.1-2008. HISTORIQUE POSIX.1-2001, 4.3BSD. NOTES La generation de nombres aleatoires est un sujet complexe. Numerical Recipes in C: The Art of Scientific Computing (William H. Press, Brian P. Flannery, Saul A. Teukolsky, William T. Vetterling ; New York : Cambridge University Press, 2007, 3e ed.) fournit une excellente discussion sur les problemes pratiques de generation de noms aleatoires dans le chapitre 7 (Random Numbers). Pour une discussion plus theorique, qui aborde egalement en profondeur d'autres domaines, voir le chapitre 3 (Random Numbers) du livre de Donald E. Knuth The Art of Computer Programming, volume 2 (Seminumerical Algorithms), 2e ed. ; Reading, Massachusetts : Addison-Wesley Publishing Company, 1981. AVERTISSEMENTS La fonction random() ne doit pas etre utilisee dans des programmes multithreades ou le comportement doit etre reproductible. Utilisez random_r(3) dans ce cas. BOGUES D'apres POSIX, initstate() devrait renvoyer NULL en cas d'erreur. Dans la mise en oeuvre de la glibc, errno est renseigne en cas d'erreur comme specifie, mais la fonction ne renvoie pas NULL. VOIR AUSSI getrandom(2), drand48(3), rand(3), random_r(3), srand(3) TRADUCTION La traduction francaise de cette page de manuel a ete creee par Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot et bubu Cette traduction est une documentation libre ; veuillez vous reporter a la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITE LEGALE. Si vous decouvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message a . Pages du manuel de Linux 6.9.1 2 mai 2024 random(3)