关于/dev/random和/dev/urandom求随机数

程序开发,脚本,各类开发工具,程序语言讨论

版主: *sake

关于/dev/random和/dev/urandom求随机数

#1  iamcook84 » 周一 3月 28日, 2016年 4:12 pm

代码: 全选
#include <sys/time.h>
#include <stdio.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdlib.h>
#include <inttypes.h>
#include <stdint.h>
#include <limits.h>
unsigned long  static openwrong=0, readwrong=0,goodnum=0,overflow=0;
unsigned long  myrandom()
{
 
  unsigned long  data;
  struct timeval ti;
  gettimeofday(&ti,NULL);
  unsigned long seed=ti.tv_usec;
 

  int fd=open("/dev/random",O_RDONLY);//1022 次以后出问题,fd<=0;
  if(fd<0 )
  {
  srandom(seed);
  data=random();
  openwrong++;   
  }
  else if (read(fd,&data,sizeof(data))<=0)
  {
      srandom(seed);
       data=random();
      readwrong++;
     }
  else if(data>SSIZE_MAX)// 有可能溢出
  {
     overflow++;
     data=data%SSIZE_MAX;
     
  }
  else goodnum++;
  return data;
}
int main(int argc, char **argv)
{
   
   unsigned long i,num=1050;//1022 次以后出问题

   for(i=1;i<num;i++)
    printf("myrandom%ld=%ld\n",i, myrandom());
    printf("openwrong=%ld,readwrong=%ld,overflow=%ld,goodnum=%ld\n",openwrong,readwrong,overflow,goodnum);
 
   return 0;
}
// 看到一本老外写的书。上面写了利用 /dev/random 和 /dev/urandom 计算伪随机数较为可信。
// 可是我试了,只可利用 1021 次。为何?
iamcook84
初心
 
帖子: 96
注册: 周三 11月 20日, 2013年 10:07 pm
Cash on hand: 159.00
送出感谢: 0 次
收到感谢: 0 次

Re: 关于/dev/random和/dev/urandom求随机数

#2  恋衣之曲 » 周一 3月 28日, 2016年 8:12 pm

Linux 下面一个程序能打开的最大文件描述符个数可以通过以下命令查看:
代码: 全选
ulimit -n

一般默认的是 1024 个,一个程序运行时会打开标准输入、标准输出和标准错误 3 个文件描述符,看一下你的 open 函数
代码: 全选
int fd=open("/dev/random",O_RDONLY);

由于你没有调用 close 函数关闭 fd,每运行一次 open 函数就会打开一个文件描述符,当运行到第 1021 次的时候,程序已经打开了 1024 个文件描述符,再运行第 1022 次的时候 open 函数就会打开错误。解决方法就是关闭已经打开的文件描述符,在 myrandom 函数中 return data 的前面加上下面一行代码:
代码: 全选
close(fd);
头像
恋衣之曲
使徒
 
帖子: 328
注册: 周一 12月 16日, 2013年 12:05 pm
Cash on hand: 276.10
Bank: 36.80
送出感谢: 1
收到感谢: 53


回到 开发与开发工具

在线用户

正在浏览此版面的用户:没有注册用户 和 1 位游客