java随机数生成器
一.java.lang.Math.Random
调用这个Math.Random()函数能够返回带正号的double值,取值范围是[0.0,1.0)的左闭右开区间,并在该范围内(近似)均匀分布。
二.java.util.Random
常用函数
- protected int next(int bits):生成下一个伪随机数。
- boolean nextBoolean():返回下一个伪随机数,它是取自此随机数生成器序列的均匀分布的boolean值。
- void nextBytes(byte[] bytes):生成随机字节并将其置于用户提供的 byte 数组中。
- double nextDouble():返回下一个伪随机数,它是取自此随机数生成器序列的、在0.0和1.0之间均匀分布的 double值。
- float nextFloat():返回下一个伪随机数,它是取自此随机数生成器序列的、在0.0和1.0之间均匀分布float值。
- double nextGaussian():返回下一个伪随机数,它是取自此随机数生成器序列的、呈高斯(“正态”)分布的double值,其平均值是0.0标准差是1.0。
- int nextInt():返回下一个伪随机数,它是此随机数生成器的序列中均匀分布的 int 值。
- int nextInt(int n):返回一个伪随机数,它是取自此随机数生成器序列的、在(包括和指定值(不包括)之间均匀分布的int值。
- long nextLong():返回下一个伪随机数,它是取自此随机数生成器序列的均匀分布的 long 值。
- void setSeed(long seed):使用单个 long 种子设置此随机数生成器的种子。
构造函数
- public Random() 该构造方法使用一个和当前系统时间对应的相对时间有关的数字作为种子数,然后使用这个种子数构造Random对象。
- public Random(long seed) 该构造方法可以通过制定一个种子数进行创建。
总结:
- 种子数只是随机算法的起源数字,和生成的随机数字的区间无关;相同种子数的Random对象,相同次数生成的随机数字是完全相同的;
- 生成[0,n)区间的数有公式Math.abs(nextInt()%n)和nextInt(n)
- 生成任意区间[a,b),公式nextInt(b-a)+a和Math.abs(nextInt()%(b-a)+a
- 生成任意区间[a,b],公式nextInt(b+1-a)+a和Math.abs(nextInt()%(b+1-a)+a)
示例代码:
package com.random; import java.util.Random; import org.junit.After;
import org.junit.Assert;
import org.junit.BeforeClass;
import org.junit.Ignore;
import org.junit.Test; public class testRandom { private static Random r1;
private static Random r2; /**
* @Title: loadUp
* @Description: 测试之前的初始化工作
*/
@BeforeClass
public static void loadUp() {
r1 = new Random(10);
r2 = new Random(10);
} @After
public void testAfter() {
System.out.println("------------------------>");
} /**
* @Title: testMathRandom
* @Description: 通过Math.random产生[0,5)之间的数
* @throws
*/
@Ignore
@Test
public void testMathRandom() {
for (int i = 0; i < 20; i++) {
System.out.println((int) (Math.random() * 5));
}
} /**
* @Title: testTwoRandom
* @Description: 两个random对象,具有相同的种子,会产生相同的随机数(伪随机)
*/
@Test
public void testTwoRandom() {
for (int i = 0; i < 10; ++i) {
Assert.assertEquals(r1.nextInt(), r2.nextInt());
}
} /**
* @Title: testRandom1
* @Description: 产生[1,2.5)之间的数的,有公式 nextDouble()*(b-a)+a
* @param 设定文件
* @return void 返回类型
* @throws
*/
@Test
@Ignore
public void testRandom1() {
for (int i = 0; i < 10; ++i) {
System.out.println(r1.nextDouble() * 1.5 + 1);
}
} /**
* @Title: testRandom2
* @Description: 产生[0,10)的两种方法,生成[0,n)区间的数有公式Math.abs(nextInt()%n)和nextInt(n)
*/
@Test
@Ignore
public void testRandom2() {
for (int i = 0; i < 10; ++i) {
System.out.println("方法一: " + r1.nextInt(10));
System.out.println("方法二: " + Math.abs(r2.nextInt() % 10));
}
} /**
* @Title: testNextBoolean
* @Description: 生成一个随机的boolean值,true和false值均等
*/
@Test
@Ignore
public void testNextBoolean() {
for (int i = 0; i < 10; ++i) {
System.out.println(r1.nextBoolean());
}
} /**
* @Title: testNextInt
* @Description: 生成一个-2^31~2^31-1之间的随机数
*/
@Test
@Ignore
public void testNextInt() {
for (int i = 0; i < 10; ++i) {
System.out.println(Math.abs(r1.nextInt()));// 0~2^31-1
System.out.println(r1.nextInt());// -2^31~2^31-1
System.out.println(r1.nextInt(10));// [0,10),参数10为随机生成数字的上限
}
} /**
* @Title: testNextDouble
* @Description: 随机生成[0,1.0)区间的小数
*/
@Test
@Ignore
public void testNextDouble() {
for (int i = 0; i < 10; ++i) {
System.out.println(r1.nextDouble());
}
} /**
* @Title: testRandom3
* @Description: 生成任意区间[a,b),公式nextInt(b-a)+a和Math.abs(nextInt()%(b-a)+a),例如区间[-3,15)
*/
@Test
@Ignore
public void testRandom3() {
for (int i = 0; i < 100; ++i) {
System.out.println(r1.nextInt(18) - 3);
System.out.println(Math.abs(r1.nextInt()%18)-3);
}
} /**
* @Title: testRandom4
* @Description: 生成任意区间[a,b],公式nextInt(b+1-a)+a和Math.abs(nextInt()%(b+1-a)+a),例如区间[3,10]
*/
@Test
public void testRandom4(){
for(int i=0;i<20;++i){
System.out.println(r1.nextInt(8)+3);
}
}
}
三.可以通过java.util.Random实现几率控制
在前面的方法介绍中,nextInt(int n)方法中生成的数字是均匀的,也就是说该区间内部的每个数字生成的几率是相同的。那么如果生成一个[0,100)区间的随机整数,则每个数字生成的几率应该是相同的,而且由于该区间中总计有100个整数,所以每个数字的几率都是1%。按照这个理论,可以实现程序中的几率问题。
示例代码:
@Test
public void testRandom5() {
for (int i = 0; i < 100; ++i) {
int a = r1.nextInt(100);
if (a < 55) {
System.out.println("1");// 55%的几率
} else if (a < 95) {
System.out.println("2");// 40%的几率
} else {
System.out.println("3");// 5%的几率
}
}
}
java随机数生成器的更多相关文章
- 解密随机数生成器(二)——从java源码看线性同余算法
Random Java中的Random类生成的是伪随机数,使用的是48-bit的种子,然后调用一个linear congruential formula线性同余方程(Donald Knuth的编程艺术 ...
- Java中的随机数生成器:Random,ThreadLocalRandom,SecureRandom(转)
文中的 Random即:java.util.Random,ThreadLocalRandom 即:java.util.concurrent.ThreadLocalRandomSecureRandom即 ...
- Java中的随机数生成器:Random,ThreadLocalRandom,SecureRandom
Java中的随机数生成器:Random,ThreadLocalRandom,SecureRandom 文中的 Random即:java.util.Random,ThreadLocalRandom 即: ...
- [转]Java中的随机数生成器:Random,ThreadLocalRandom,SecureRandom
详见: http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp84 Random即:java.util.Random, ThreadL ...
- 随机数生成器java实现
/** 设计一个随机数生成器,可以产生给定平均概率的随机证书序列. 即输入一个概率比如:0.9 然后输入要求的概率样本个数比如:1000 输出一个接近所输入的0.9的概率数(要求样本数越大越接近输入的 ...
- Java 随机数
本章先讲解Java随机数的几种产生方式,然后通过示例对其进行演示. 广义上讲,Java中的随机数的有三种产生方式:(01). 通过System.currentTimeMillis()来获取一个当前时间 ...
- Java随机数
本章先讲解Java随机数的几种产生方式,然后通过示例对其进行演示. 广义上讲,Java中的随机数的有三种产生方式:(01). 通过System.currentTimeMillis()来获取一个当前时间 ...
- java 随机数产生 常用类及方法
1.Random类 Random():创建一个新的随机数生成器. new一个Random类的对象: Random r = new Random(); 利用该对象产生一个随机整数:常用nextInt,不 ...
- 实现java随机数Random的几招
一,在java.util这个包里面提供了一个Random的类,我们可以新建一个Random的对象来产生随机数,可以产生随机整数.随机float.随机double,随机long,这个也是我们经常用的一个 ...
随机推荐
- boost 相等与等价的区别
- Eclipse中Java文件图标由实心J变成空心J的问题
在eclipse中空心J的java文件,表示不被包含在项目中进行编译,而是当做资源存在项目中.例如 当是单个文件为空心J的时候 1.右击该文件 -- >BuildPath -->Inclu ...
- MM32 RTC学习(兼容STM32)
RTC学习 RTC简述 实时时钟是一个独立的定时器. RTC模块拥有一组连续计数的计数器,在相应软件配置下,可提供时钟日历的功能. 修改计数器的值可以重新设置系统当前的时间和日期. RTC模块和时钟配 ...
- wpf的学习日志(一)
今天开始学习wpf,从xaml的布局开始 stackpanel布局:Orientation决定布局的横向还是纵向,HorizontalAlignment决定布局的对齐 <StackPanel O ...
- (转)TortoiseSVN使用简介
TortoiseSVN使用简介 TortoiseSVN使用简介 2009-04-24 来源:dev.idv.tw 1 安装及下载client 端 2 什么是SVN(Subversion)? 3 为甚么 ...
- MySQL MyISAM/InnoDB高并发优化经验
最近做的一个应用,功能要求非常简单,就是 key/value 形式的存储,简单的 INSERT/SELECT,没有任何复杂查询,唯一的问题是量非常大,如果目前投入使用,初期的单表 insert 频率约 ...
- C# 导出word文档及批量导出word文档(3)
在初始化WordHelper时,要获取模板的相对路径.获取文档的相对路径多个地方要用到,比如批量导出时要先保存文件到指定路径下,再压缩打包下载,所以专门写了个关于获取文档的相对路径的类. #regio ...
- OREACLE 数据库建表 添加判断表是否存在 不存在则新建
declare cnt number; begin ---查询要创建的表是否存在 select count(*)into cnt from user_tables where table_n ...
- PHP学习系列(1)——字符串处理函数(4)
16.hebrevc() 函数把希伯来文本从右至左的流转换为左至右的流.它也会把新行 (\n) 转换为 <br />.只有 224 至 251 之间的 ASCII 字符,以及标点符号受到影 ...
- PHP文章管理(2)
##############index.php###################### <?session_start(); require"./inc/func.php&qu ...