#include <stdlib.h> int rand(void); int rand_r(unsigned int *seedp); void srand(unsigned int seed);
Exigences de macros de test de fonctionnalités pour la glibc (voir feature_test_macros(7)) :
rand_r() : _POSIX_C_SOURCE || _XOPEN_SOURCE
La fonction srand() utilise son argument comme « graine » pour la génération d'une nouvelle séquence de nombres pseudo-aléatoires, qui seront fournis par rand(). Ces séquences sont reproductibles en appelant srand() avec la même valeur de graine.
Si aucune graine originale n'est fournie, la fonction rand() commence en utilisant la valeur 1.
La fonction rand() n'est ni réentrante ni sûre en contexte multithreads, car elle utilise un état interne modifié à chaque appel. Il peut s'agir simplement de la valeur de graine aléatoire pour l'appel suivant, ou il peut s'agir de quelquechose de plus compliqué. Afin d'obtenir un comportement reproductible dans une application multithreads, cet état doit être stocké dans une variable fournie explicitement. La fonction rand_r() est appelée avec un pointeur vers un unsigned int qui servira d'état d'interne. Il s'agit d'une donnée très petite pour stocker la valeur d'état, cette fonction sera donc un générateur pseudo-aléatoire faible. Essayez donc drand48_r(3) à sa place.
static unsigned long suivant = 1; /* RAND_MAX supposé être égal à 32767 */ int mon_rand(void) { suivant = suivant * 1103515245 + 12345; return((unsigned)(suivant/65536) % 32768); } void mon_srand(unsigned graine) { suivant = graine; }
Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 5 novembre 1996 et révisée le 17 juillet 2008.
L'équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=C man 3 rand ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.
Dernière mise à jour : 17 juillet 2008