Scroll to navigation

random(3) Library Functions Manual random(3)

NOM

random, srandom, initstate, setstate - Gnrateur de nombres alatoires

BIBLIOTHÈQUE

Bibliothèque C standard (libc, -lc)

SYNOPSIS

#include <stdlib.h>
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 fonctionnalités 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 RENVOYÉE

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

Le paramtre tat de setstate() tait NULL.
Une table d'tats de moins de 8 octets a t fournie initstate().

ATTRIBUTS

Pour une explication des termes utilisés dans cette section, consulter attributes(7).

Interface Attribut Valeur
random(), srandom(), initstate(), setstate() Sécurité des threads MT-Safe

STANDARDS

POSIX.1-2001, POSIX.1-2008, 4.3BSD.

NOTES

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.

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.

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 française de cette page de manuel a été créée par #-#-#-#-# min-002-occurences.po (perkamon) #-#-#-#-#, Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan.rafin@laposte.net>, Thierry Vignaud <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>, Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org>, Jean-Philippe MENGUAL <jpmengual@debian.org>, Jean-Pierre Giraud <jean-pierregiraud@neuf.fr>, #-#-#-#-# min-003-occurences.po (perkamon) #-#-#-#-#, Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan.rafin@laposte.net>, Thierry Vignaud <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>, Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org>, Jean-Philippe MENGUAL <jpmengual@debian.org>, Jean-Pierre Giraud <jean-pierregiraud@neuf.fr>, #-#-#-#-# min-004-occurences.po (perkamon) #-#-#-#-#, Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan.rafin@laposte.net>, Thierry Vignaud <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>, Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org>, Jean-Philippe MENGUAL <jpmengual@debian.org>, Jean-Pierre Giraud <jean-pierregiraud@neuf.fr>, #-#-#-#-# min-010-occurences.po (perkamon) #-#-#-#-#, Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan.rafin@laposte.net>, Thierry Vignaud <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>, Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org>, Thomas Vincent <tvincent@debian.org>, #-#-#-#-# min-020-occurences.po (perkamon) #-#-#-#-#, Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan.rafin@laposte.net>, Thierry Vignaud <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>, Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org>, Jean-Philippe MENGUAL <jpmengual@debian.org>, Jean-Pierre Giraud <jean-pierregiraud@neuf.fr>, #-#-#-#-# min-100-occurences.po (perkamon) #-#-#-#-#, Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan.rafin@laposte.net>, Thierry Vignaud <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>, Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org>, Jean-Philippe MENGUAL <jpmengual@debian.org>, Jean-Pierre Giraud <jean-pierregiraud@neuf.fr> et #

Cette traduction est une documentation libre ; veuillez vous reporter à la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.

Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à debian-l10n-french@lists.debian.org.

10 février 2023 Pages du manuel de Linux 6.03