java中random()函数用法介绍

Random()

创建一个新的随机数生成器。
 

 代码如下 复制代码
Random(long seed)

使用单个 long 种子创建一个新的随机数生成器。

我们可以在构造Random对象的时候指定种子,如:

 代码如下 复制代码

Random r1 = new Random(20);

或者默认当前系统时间对应的相对时间有关的数字作为种子数:

 代码如下 复制代码

Random r1 = new Random();

种子数只是随机算法的起源数字,和生成的随机数字的区间无关。

2、Random类中的常用方法

下面对这些方法做一下基本的介绍:

 代码如下 复制代码

a、public boolean nextBoolean()

该方法的作用是生成一个随机的boolean值,生成true和false的值几率相等,也就是都是50%的几率。

 代码如下 复制代码

b、public double nextDouble()

该方法的作用是生成一个随机的double值,数值介于[0,1.0)之间。

 

 代码如下 复制代码
c、public int nextInt()

该方法的作用是生成一个随机的int值,该值介于int的区间,也就是-231到231-1之间。

如果需要生成指定区间的int值,则需要进行一定的数学变换,具体可以参看下面的使用示例中的代码。

 代码如下 复制代码
d、public int nextInt(int n

)

该方法的作用是生成一个随机的int值,该值介于[0,n)的区间,也就是0到n之间的随机int值,包含0而不包含n。

如果想生成指定区间的int值,也需要进行一定的数学变换,具体可以参看下面的使用示例中的代码。

 代码如下 复制代码

e、public void setSeed(long seed)

该方法的作用是重新设置Random对象中的种子数。设置完种子数以后的Random对象和相同种子数使用new关键字创建出

的Random对象相同。

3、Random类使用示例

使用Random类,一般是生成指定区间的随机数字,下面就一一介绍如何生成对应区间的随机数字。以下生成随机数的

代码均使用以下Random对象r进行生成:

 代码如下 复制代码

Random r = new Random();

a、生成[0,1.0)区间的小数

 代码如下 复制代码

double d1 = r.nextDouble();

直接使用nextDouble方法获得。

b、生成[0,5.0)区间的小数

 代码如下 复制代码

double d2 = r.nextDouble() * 5;

因为nextDouble方法生成的数字区间是[0,1.0),将该区间扩大5倍即是要求的区间。

同理,生成[0,d)区间的随机小数,d为任意正的小数,则只需要将nextDouble方法的返回值乘以d即可。

c、生成[1,2.5)区间的小数

 代码如下 复制代码

       double d3 = r.nextDouble() * 1.5 + 1;

生成[1,2.5)区间的随机小数,则只需要首先生成[0,1.5)区间的随机数字,然后将生成的随机数区间加1即可。

同理,生成任意非从0开始的小数区间[d1,d2)范围的随机数字(其中d1不等于0),则只需要首先生成[0,d2-d1)区间的

随机数字,然后将生成的随机数字区间加上d1即可。

d、生成任意整数

 代码如下 复制代码

int n1 = r.nextInt();

直接使用nextInt方法即可。

e、生成[0,10)区间的整数

 代码如下 复制代码

int n2 = r.nextInt(10);

n2 = Math.abs(r.nextInt() % 10);

以上两行代码均可生成[0,10)区间的整数

均匀分布性

 代码如下 复制代码

import java.util.Random;
 
public class RandomDemo {
    /**
     * 小伙部落
     *
     * @param args
     */
    public static void main(String[] args) {
        Random r = new Random();
        int n5 = r.nextInt(100);
        String ran = "";
        if (n5 < 55) {       //55个数字的区间,55%的几率
            ran = "55%";
        } else if (n5 < 95) {//[55,95),40个数字的区间,40%的几率
            ran = "40%";
        } else {
            ran = "5%";     //剩余几率,你懂得!
        }
        System.out.println(ran);
    }
}

时间: 2025-01-25 12:17:11

java中random()函数用法介绍的相关文章

PHP中array_slice函数用法介绍

array_slice() 函数在数组中根据条件取出一段值,并返回. 注释:如果数组有字符串键,所返回的数组将保留键名.(参见例子 4) 语法 array_slice(array,offset,length,preserve) 函数在数组中根据条件取出一段值,并返回 参数  array  必需.规定输入的数组. offset  必需.数值.规定取出元素的开始位置.如果是正数,则从前往后开始取,如果是负值,从后向前取 offset 绝对值. length  可选.数值.规定被返回数组的长度.如果是

php中parse_url()函数用法介绍

PHP中一个好用的函数parse_url,特别方便用来做信息抓取的分析,举例子如下:  代码如下 复制代码 $url = "http://www.111cn.net/aaaa/";$parts = parse_url($url); 输出: Array (     [scheme] => http     [host] => www.111cn.net     [path] => /aaaa/ ) 又如:  代码如下 复制代码 <?php$url = 'http:

php中setcookie() 函数用法介绍

setcookie() 函数向客户端发送一个 HTTP cookie. cookie 是由服务器发送到浏览器的变量.cookie 通常是服务器嵌入到用户计算机中的小文本文件.每当计算机通过浏览器请求一个页面,就会发送这个 cookie. cookie 的名称指定为相同名称的变量.例如,如果被发送的 cookie 名为 "name",会自动创建名为 $user 的变量,包含 cookie 的值. 必须在任何其他输出发送前对 cookie 进行赋值. 如果成功,则该函数返回 true,否则

Java中split()函数和trim()函数的用法

split()函数是根据参数如",", "-", " "等, 分割String字符串, 返回一个String的数组(String[]), 可以通过索引指定元素. 如果未找到, 则返回整个String字符串, 作为String数组(String[])的第0个元素. trim()函数是去掉String字符串的首尾空格; 代码: /** * @author Spike * @time 2014.4.25 */ public class Split {

PHP中error_reporting函数用法详细介绍

PHP中error_reporting函数用法详细介绍 PHP中对错误的处理会用到error_reporting函数,看到最多的是error_reporting(E_ALL ^ E_NOTICE),这个是什么意思呢?下面我们具体分析error_reporting函数. 定义用法 error_reporting() 设置 PHP 的报错级别并返回当前级别. 语法 error_reporting(report_level) 如果参数 report_level 未指定,当前报错级别将被返回.下面几项是

python中enumerate函数用法实例分析

  本文实例讲述了python中enumerate函数用法.分享给大家供大家参考.具体分析如下: 今日发现一个新函数 enumerate .一般情况下对一个列表或数组既要遍历索引又要遍历元素时,会这样写: ? 1 2 for i in range (0,len(list)): print i ,list[i] 但是这种方法有些累赘,使用内置enumerrate函数会有更加直接,优美的做法,先看看enumerate的定义: ? 1 2 3 4 5 6 7 def enumerate(collect

Excel中sumif函数用法

今天接着给大家来关于Excel中sumif函数用法的操作技巧,那么就有人问了,学会了Excel中sumif函数用法有什么作用呢,不要急,下面就请听小编一一给大家进行详细的讲解: 一.SUMIF函数介绍 SUMIF函数根据指定条件对若干单元格求和,该条件可以是数值.文本或表达式,可以应用在人事.工资和成绩统计中. 二.SUMIF函数用法 sumif函数语法是:SUMIF(range,criteria,sum_range) 第一个参数:Range为条件区域,用于条件判断的单元格区域. 第二个参数:C

java中final的用法

许多程序设计语言都有自己的办法告诉编译器某个数据是"常数".常数主要应用于下述两个方面: (1) 编译期常数,它永远不会改变 (2) 在运行期初始化的一个值,我们不希望它发生变化 对于编译期的常数,编译器(程序)可将常数值"封装"到需要的计算过程里.也就是说,计算可在编译期间提前执行,从而节省运行时的一些开销.在Java中,这些形式的常数必须属于基本数据类型(Primitives),而且要用final关键字进行表达.在对这样的一个常数进行定义的时候,必须给出一个值.

javascript中eval函数用法分析

  javascript中eval函数用法分析         这篇文章主要介绍了javascript中eval函数用法,实例分析了javascript中eval函数的使用技巧,非常具有实用价值,需要的朋友可以参考下 本文实例分析了javascript中eval函数用法.分享给大家供大家参考.具体分析如下: eval()只有一个参数,如果传入的参数不是字符串,则直接返回这个参数.否则会将字符串当成js代码进行编译,如果编译失败则抛出语法错误(SyntaxError)异常.如果编译成功则开始执行这