random(3) Library Functions Manual random(3) NOM random, srandom, initstate, setstate - Gnrateur de nombres alatoires BIBLIOTHEQUE Bibliotheque C standard (libc, -lc) SYNOPSIS #include long random(void); void srandom(unsigned int graine); char *initstate(unsigned int graine, char tat, size_t n); char *setstate(char *tat); 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 gnrateur de nombre alatoire non linaire (non-linear additive feedback random number generator) utilisant une table par dfaut de 31 entiers longs pour renvoyer successivement des nombres pseudoalatoires entre 0 et 2^31 - 1. La priode de ce gnrateur est trs grande, approximativement 16 * ((2^31) - 1). La fonction srandom() utilise son argument comme graine pour engendrer une nouvelle squence de nombres pseudoalatoires qui seront fournis lors des appels random(). Ces squences sont reproductibles en invoquant srandom() avec la mme graine. Si aucune graine n'est fournie, La fonction random() utilise automatiquement une graine originale de valeur 1. La fonction initstate() permet d'initialiser une table d'tats state pour l'utiliser avec random(). La taille n de la table est utilise par initstate() pour dterminer le niveau de sophistication du gnrateur de nombres alatoires. Plus grande est la table d'tats, meilleurs seront les nombres alatoires. Les valeurs optimales pour la taille de la table d'tats n sont 8, 32, 64, 128 et 256octets; 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 dpart pour la squence de nombres alatoires, et permet de redmarrer au mme endroit. La fonction setstate() modifie la table d'tats utilise par la fonction random(). La table d'tats tat est alors utilise comme gnrateur de nombres alatoires jusqu'au prochain appel de initstate() ou setstate(). tat doit d'abord tre initialise avec initstate() ou tre le rsultat d'un appel prcdent setstate(). VALEUR RENVOYEE La fonction random() renvoie une valeur entre0 et (2^31) - 1. La fonction srandom() ne renvoie pas de valeur. La fonction initstate() renvoie un pointeur sur la table d'tats prcdente. En cas d'chec, elle renvoie NULL et errno contient le code d'erreur. La fonction setstate() renvoie un pointeur sur la table d'tats prcdente. En cas d'chec, NULL est renvoy et errno est dfini pour indiquer l'erreur. ERREURS EINVAL Le paramtre tat de setstate() tait NULL. EINVAL Une table d'tats de moins de 8 octets a t fournie 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 gnration de nombres alatoires 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, 3ed.) fournit une excellente discussion sur les problmes pratiques de gnration de noms alatoires dans le chapitre7 (Random Numbers). Pour une discussion plus thorique, qui aborde galement en profondeur d'autres domaines, voir le chapitre3 (Random Numbers) du livre de Donald E. Knuth The Art of Computer Programming, volume2 (Seminumerical Algorithms), 2ed.; Reading, Massachusetts: Addison-Wesley Publishing Company, 1981. CAVEATS La fonction random() ne doit pas tre utilise dans des programmes multithreads o le comportement doit tre reproductible. Utilisez random_r(3) dans ce cas. BOGUES D'aprs POSIX, initstate() devrait renvoyer NULL en cas d'erreur. Dans la mise en uvre de la glibc, errno est renseign en cas d'erreur comme spcifi, 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 #-#-#-#-# min-002-occurences.po (perkamon) #-#-#-#-#, 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 , Jean-Philippe MENGUAL , Jean-Pierre Giraud , #-#-#-#-# min-003-occurences.po (perkamon) #-#-#-#-#, 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 , Jean-Philippe MENGUAL , Jean-Pierre Giraud , #-#-#-#-# min-004-occurences.po (perkamon) #-#-#-#-#, 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 , Jean-Philippe MENGUAL , Jean-Pierre Giraud , #-#-#-#-# min-010-occurences.po (perkamon) #-#-#-#-#, 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 , Thomas Vincent , #-#-#-#-# min-020-occurences.po (perkamon) #-#-#-#-#, 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 , Jean-Philippe MENGUAL , Jean-Pierre Giraud , #-#-#-#-# min-100-occurences.po (perkamon) #-#-#-#-#, 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 , Jean-Philippe MENGUAL , Jean-Pierre Giraud et # 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.06 31 octobre 2023 random(3)