您的位置:首页 > 运维架构 > Linux

linux产生随机数

2015-12-15 18:53 260 查看


rand函数

函数rand()是真正的随机数生成器,而srand()会设置供rand()使用的随机数种子。函数rand()会返回一个处于0和你所指定的数值(缺 省为1)之间的分数。如果你在第一次调用rand()之前没有调用srand(),那么系统会为你自动调用srand()。而使用同种子相同的数调用 srand()会导致相同的随机数序列被生成。

  srand((unsigned)time(NULL))则使用系统定时/计数器的值做为随机种子,所以,在相同的平台环境下,显示的随机数会是伪随机数,即每次运行显示的结果会有不同。

  库函数中系统提供了两个函数用于产生随机数:srand()和rand()。 原型为:

  函数一:int rand(void);

  从srand (seed)中指定的seed开始,返回一个[0, RAND_MAX(0x7fff)]间的随机整数。

  函数二:void srand(unsigned seed);

  参数seed是rand()的种子,用来初始化rand()的起始值。

  但是,要注意的是所谓的“伪随机数”指的并不是假的随机数。其实绝对的随机数只是一种理想状态的随机数,计算机只能生成相对的随机数即伪随机数。计算机生 成的伪随机数既是随机的又是有规律的 —— 一部份遵守一定的规律,一部份则不遵守任何规律。比如“世上没有两片形状完全相同的树叶”,这正点到了事物的特性
—— 规律性;但是每种树的叶子都有近似的形状,这正是事物的共性 —— 规律性。从这个角度讲,我们就可以接受这样的事实了:计算机只能产生伪随机数而不是绝对的随机数。

  系统在调用rand()之前都会自动调用srand(),如果用户在rand()之前曾调用过srand()给参数seed指定了一个值,那么 rand()就会将seed的值作为产生伪随机数的初始值;而如果用户在rand()前没有调用过srand(),那么系统默认将1作为伪随机数的初始
值。如果给了一个定值,那么每次rand()产生的随机数序列都是一样的~~

  所以为了避免上述情况的发生我们通常用srand((unsigned)time(0))或者srand((unsigned)time(NULL))来 产生种子。如果仍然觉得时间间隔太小,可以在(unsigned)time(0)或者(unsigned)time(NULL)后面乘上某个合适的整数。
例如,srand((unsigned)time(NULL)*10)

  另外,关于time_t time(0):time_t被定义为长整型,它返回从1970年1月1日零时零分零秒到目前为止所经过的时间,单位为秒。

  关于求值区域的问题:要取得[a,b)之间的随机整数,使用(rand() % (b-a))+ a (结果值将含a不含b)。

  在a为0的情况下,简写为rand() % b。

http://baike.baidu.com/view/5876059.htm

//---------------------------------------------------------------------------


Linux系统下如何产生随机数

最近需要编写一个产生随机数的函数,在网上搜索了很久,发现好多人提供的方法不是很妥当,产生的随机数的随机性不够好。一般的方法是:例如产生一个随机数在1~100之间的数,

有的人会使用如下方法:

srand(time(0));

rand()%100+1;

这样可以产生符合要求的随机数,但是,随机性不太好,因为使用time(0)作为种子,在一秒之内种子是不会变得。

另外,看大srand的帮助可以知道,不建议使用%去获取随机数。另外,可以通过使用微妙,来增加随机数的随机性。例子如下:

struct timeval tpstart;

gettimeofday(&tpstart,NULL);

srand(tpstart.tv_usec);

1+(int) (100.0*rand()/(RAND_MAX+1.0));

RAND_MAX是系统的一个宏。

通过下面的程序测试,随机数的分布的比使用time(0)的结果要均匀一些。

#include <stdio.h>

#include <stdlib.h>

#include <time.h>

#include <sys/time.h>

int main()

{

struct timeval tpstart;

int n = 100;

int nn = 0;

for (nn=0;nn<300;nn++)

{

gettimeofday(&tpstart,NULL);

srand(tpstart.tv_usec);

//srand( (unsigned)time( NULL ) );

n = (1+(int) (300.0*rand()/(RAND_MAX+1.0)));

//printf("%d \n",n);

if (n<=100)

{

printf("%d AAAA\n", n);

}

else if (n <= 200)

{

printf("%d BBBB\n", n);

}

else if (n<=300)

{

printf("%d CCCC\n", n);

}

else

{

printf("Error\n");

}

sleep(1);

}

return 0;

}

转载:http://blog.csdn.net/imxiangzi/article/details/7710982
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: