package test2;

import java.util.Random;

/**
* @author cy
*
* @date 2015年7月28日 上午8:47:52
*
* @Description TODO
*/ public class Enums {
private static Random rand = new Random() ; // 为什么一直是47
public static <T extends Enum<T>> T random(Class<T> ec ){
return random(ec.getEnumConstants()) ;
}
public static <T> T random(T[] values ){
int x = rand.nextInt(values.length) ;
System.out.println("x: " + x);
return values[x] ;
}
public static void main(String[] args) {
for( int i = 0 ; i < 10 ; i ++){
System.out.println(rand.nextInt(3));
}
System.out.println("=============");
for( int i = 0 ; i < 11 ; i ++){
System.out.println(rand.nextInt(3));
}
}
}

上面的这个程序的输出序列不会发生变化。

下面的这个程序输出也不会发生变化。但是我本来是想达到每次运行都不同,达到随机的效果。

package test2;

/**
* @author cy
*
* @date 2015年7月28日 上午9:34:32
*
* @Description TODO
*/
public enum SecurityCategory {
STOCK(Security.Stock.class), BOND(Security.Bond.class);
public Security[] values; private SecurityCategory(Class<? extends Security> security) {
values = security.getEnumConstants();
} interface Security {
enum Stock implements Security {
SHORT, LONG, MARGIN
} enum Bond implements Security {
MUNICIPAL, JUNK
}
} public Security randomSelect() {
return Enums.random(values);
} public static void main(String[] args) {
/**
* 这个程序的输出不会出现随机出现的效果,
* 原因: 一个java程序运行就会打开一个java虚拟机
* (可以观察在系统进程中会有多个javaw.exe的进程
* ,因为打开一个eclipse会有多个功能模块依靠java虚拟机运行,JVM只有一个,但有多个虚拟机实例 ),
* 当程序关闭了相应的虚拟机实例也就关闭了。在该程序中有两点需要注意,1. 带有固定种子数的Random产生的随机数是
* 一个固定序列。2. 每当运行程序时,静态的Random对象就会重新初始化,所以产出的随机序列就一直不变。
* 所以会出现这样的运行结果:
* 在Enums.java中运行main方法输出的结果一直是不变的。而且在这个程序中的输出也一直是不变的。
* 如果在Random对象中不填种子数,API中是这样写的
* “创建一个新的随机数生成器。此构造方法将随机数生成器的种子设置为某个值,该值与此构造方法的所有其他调用所用的值完全不同”
* 虽然我没有明白这是啥意思,估计是说产生独一无二的的种子数。
*
*/
for (SecurityCategory s : SecurityCategory.values()) {
/*
* for(Security c : s.values){ System.out.println(c); }
*/
System.out.println(s.randomSelect());
System.out.println("============");
} }
}

原因写在注释中了~~~~~~~~~~

关于Random类产生随机数的一些问题的更多相关文章

  1. .Net使用system.Security.Cryptography.RNGCryptoServiceProvider类与System.Random类生成随机数

    .Net中我们通常使用Random类生成随机数,在一些场景下,我却发现Random生成的随机数并不可靠,在下面的例子中我们通过循环随机生成10个随机数: ; i < ; i++) { Rando ...

  2. 高并发分布式系统中生成全局唯一(订单号)Id js返回上一页并刷新、返回上一页、自动刷新页面 父页面操作嵌套iframe子页面的HTML标签元素 .net判断System.Data.DataRow中是否包含某列 .Net使用system.Security.Cryptography.RNGCryptoServiceProvider类与System.Random类生成随机数

    高并发分布式系统中生成全局唯一(订单号)Id   1.GUID数据因毫无规律可言造成索引效率低下,影响了系统的性能,那么通过组合的方式,保留GUID的10个字节,用另6个字节表示GUID生成的时间(D ...

  3. Random类(随机数)

    前言:总是忘记怎么用.上网一查,都是些有的没的...... 最简单却最常用的方法:Random.Next方法 首先,为Random类实例化一个对象: Random n=new Random(); Ne ...

  4. 【代码笔记】Java常识性基础补充(一)——赋值运算符、逻辑运算符、三元运算符、Scanner类、键盘输入、Random类、随机数

    为什么要进行Java常识性基础补充? 之前学习Java语言,学得很多很杂,而且是很多不同的方面插入讲解的,比如在跟班上课,自学java编程例子,java语法,过了很久,因为各种原因长时间不怎么写,有时 ...

  5. Random 类生成随机数

    Random类 (java.util) Random类中实现的随机算法是伪随机,也就是有规则的随机.在进行随机时,随机算法的起源数字称为种子数(seed),在种子数的基础上进行一定的变换,从而产生需要 ...

  6. Random类产生随机数

    Random 类作为JAVA中用于产生的随机数 ,new  Random(10)  :10是种子数. 注意:Random 的一个特点是:相同种子数的Random对象,对应相同次数生成的随机数字是完全相 ...

  7. java Random类生成随机数

    封装一个方法: import java.util.Random; public class RandomUtil { /** * nextInt(num) 产生[0 ~ (num-1)]的随机数, 闭 ...

  8. Random类

    Random类是随机数产生类,可以指定一个随机数的范围,然后任意产生在此范围中的数字. //================================================= // F ...

  9. 数字(数学)操作类 Math Random 类 ,大数字操作类

    Math 提供了大量的数学操作方法 Math类中所有的方法都是static 方法

随机推荐

  1. windows下cmd操作

    进入文件夹:cd 文件夹名 列出文件列表:dir 清屏:cls

  2. Angular JS学习之表达式

    1.Angular JS使用表达式把数据绑定到HTML: 2.Angular JS表达式写在双大括号中:{{expression}} **Angular JS表达式把数据绑定到HTML,这与ng-bi ...

  3. 彻底搞懂Html5本地存储技术(一)

    一.H5之前客户端本地存储的实现 1. cookies cookies的应用比较广泛,但有以下几个问题: (1)每次http请求头上会带着,浪费资源 (2)每个域名客户端只能存储4K大小 (3)会造成 ...

  4. BZOJ3257 : 树的难题

    设$f[x][i][j]$表示以$x$为根的子树,与$x$连通部分有$i$个黑点,$j$个白点,不联通部分都是均衡的最小代价.若$i>1$,则视作$1$:若$j>2$,则视作$2$. 然后 ...

  5. BZOJ3569 : DZY Loves Chinese II

    这回是真·强制在线了,首先这道题就是AHOI2013连通图的加强版,那道题k最大只有4 那道题的做法是: 取一个生成树,对每条非树边取一个随机权值, 对每条树边设为“覆盖它的所有非树边”的权值的xor ...

  6. 使用TCMalloc优化OpenResty

    1.安装依赖包 yum -y install wget gcc gcc-c++ -y 2.安装libunwind库可以从http://ftp.twaren.net/Unix/NonGNU//libun ...

  7. ACM Haffman编码

    Haffman编码 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 哈弗曼编码大家一定很熟悉吧(不熟悉也没关系,自己查去...).现在给你一串字符以及它们所对应的权值 ...

  8. 51Nod 1002 数字三角形 Label:水水水 && 非学习区警告

    一个高度为N的由正整数组成的三角形,从上走到下,求经过的数字和的最大值. 每次只能走到下一层相邻的数上,例如从第3层的6向下走,只能走到第4层的2或9上.      5   8 4  3 6 9 7 ...

  9. transform应用详解

    关于css3的transform,做了一个demo,上代码 html: <!DOCTYPE html> <html> <head lang="en"& ...

  10. python 教程

    教程 http://www.runoob.com/python/att-list-append.html 习题 http://blog.csdn.net/liuyuan_jq/article/deta ...