名前

drand48_r, erand48_r, lrand48_r, nrand48_r, mrand48_r, jrand48_r, srand48_r, seed48_r, lcong48_r - 一様分布する疑似乱数をリエントラント (reentrant) に生成する

書式

#include <stdlib.h>
int drand48_r(struct drand48_data *buffer, double *result);
int erand48_r(unsigned short xsubi[3],
              struct drand48_data *buffer, double *result);
int lrand48_r(struct drand48_data *buffer, long *result);
int nrand48_r(unsigned short xsubi[3],
              struct drand48_data *buffer, long *result);
int mrand48_r(struct drand48_data *buffer,long *result);
int jrand48_r(unsigned short xsubi[3],
              struct drand48_data *buffer, long *result);
int srand48_r(long int seedval, struct drand48_data *buffer);
int seed48_r(unsigned short seed16v[3],
             struct drand48_data *buffer);
int lcong48_r(unsigned short param[7],
              struct drand48_data *buffer);
glibc 向けの機能検査マクロの要件 ( feature_test_macros(7) 参照):
All functions shown above:
/* Glibc since 2.19: */ _DEFAULT_SOURCE
|| /* Glibc versions <= 2.19: */ _SVID_SOURCE || _BSD_SOURCE

説明

これらの関数は drand48(3) で説明されている関数に類似するリエントラントな関数である。 大域的な乱数生成の状態を変更する代わりに、 これらの関数は指定されたデータ buffer を使う。
最初に使う前に、この構造体は初期化されていなければならない。 初期化は、たとえば 0 で埋めたり、関数 srand48_r(), seed48_r(), lcong48_r() のいずれかを呼び出すことによって行われる。

返り値

返り値は 0 である。

属性

この節で使用されている用語の説明については、 attributes(7) を参照。
インターフェース 属性
drand48_r(), erand48_r(), lrand48_r(), nrand48_r(), mrand48_r(), jrand48_r(), srand48_r(), seed48_r(), lcong48_r() Thread safety MT-Safe race:buffer

準拠

これらの関数は GNU による拡張であり、移植性はない。

関連項目

drand48(3), rand(3), random(3)

この文書について

この man ページは Linux man-pages プロジェクトのリリース 5.10 の一部である。プロジェクトの説明とバグ報告に関する情報は https://www.kernel.org/doc/man-pages/ に書かれている。

Recommended readings

Pages related to erand48_r you should read also: