转自:https://blog.csdn.net/YTTmiao/article/details/78187448

随机数在实际中使用很广泛,比如要随即生成一个固定长度的字符串、数字。或者随即生成一个不定长度的数字、或者进行一个模拟的随机选择等等。Java提供了最基本的工具,可以帮助开发者来实现这一切。

    一、Java随机数的产生方式

在Java中,随机数的概念从广义上将,有三种。

1、通过System.currentTimeMillis()来获取一个当前时间毫秒数的long型数字。

2、通过Math.random()返回一个0到1之间的double值。

3、通过Random类来产生一个随机数,这个是专业的Random工具类,功能强大。

    二、Random类API说明

1、Java API说明

Random类的实例用于生成伪随机数流。此类使用 48 位的种子,使用线性同余公式对其进行修改(请参阅 Donald Knuth 的《The Art of Computer Programming, Volume 2》,第 3.2.1 节)。

如果用相同的种子创建两个 Random 实例,则对每个实例进行相同的方法调用序列,它们将生成并返回相同的数字序列。为了保证属性的实现,为类 Random 指定了特定的算法。

很多应用程序会发现 Math 类中的 random 方法更易于使用。

2、方法摘要

  1. Random()
  2. 创建一个新的随机数生成器。
  3. Random(long seed)
  4. 使用单个 long 种子创建一个新随机数生成器: public Random(long seed) { setSeed(seed); } next 方法使用它来保存随机数生成器的状态。
  5. protected  int next(int bits)
  6. 生成下一个伪随机数。
  7. boolean nextBoolean()
  8. 返回下一个伪随机数,它是从此随机数生成器的序列中取出的、均匀分布的 boolean 值。
  9. void nextBytes(byte[] bytes)
  10. 生成随机字节并将其置于用户提供的字节数组中。
  11. double nextDouble()
  12. 返回下一个伪随机数,它是从此随机数生成器的序列中取出的、在 0.0 和 1.0之间均匀分布的 double 值。
  13. float nextFloat()
  14. 返回下一个伪随机数,它是从此随机数生成器的序列中取出的、在 0.0 和 1.0 之间均匀分布的 float 值。
  15. double nextGaussian()
  16. 返回下一个伪随机数,它是从此随机数生成器的序列中取出的、呈高斯(“正常地”)分布的 double 值,其平均值是 0.0,标准偏差是 1.0。
  17. int nextInt()
  18. 返回下一个伪随机数,它是此随机数生成器的序列中均匀分布的 int 值。
  19. int nextInt(int n)
  20. 返回一个伪随机数,它是从此随机数生成器的序列中取出的、在 0(包括)和指定值(不包括)之间均匀分布的 int值。
  21. long nextLong()
  22. 返回下一个伪随机数,它是从此随机数生成器的序列中取出的、均匀分布的 long 值。
  23. void setSeed(long seed)
  24. 使用单个 long 种子设置此随机数生成器的种子。

三、Random类使用说明

1、带种子与不带种子的区别Random类使用的根本是策略分带种子和不带种子的Random的实例。

通俗说,两者的区别是:带种子的,每次运行生成的结果都是一样的。

不带种子的,每次运行生成的都是随机的,没有规律可言。

2、创建不带种子的Random对象

Random random = new Random();

3、创建不带种子的Random对象有两种方法:

1) Random random = new Random(555L);

2) Random random = new Random();random.setSeed(555L);

    四、测试

通过一个例子说明上面的用法

  1. import java.util.Random;
  2. public class TestRandomNum {
  3. public static void main(String[] args) {
  4. randomTest();
  5. testNoSeed();
  6. testSeed1();
  7. testSeed2();
  8. }
  9. public static void randomTest() {
  10. System.out.println("--------------test()--------------");
  11. //返回以毫秒为单位的当前时间。
  12. long r1 = System.currentTimeMillis();
  13. //返回带正号的 double 值,大于或等于 0.0,小于 1.0。
  14. double r2 = Math.random();
  15. //通过Random类来获取下一个随机的整数
  16. int r3 = new Random().nextInt();
  17. System.out.println("r1 = " + r1);
  18. System.out.println("r3 = " + r2);
  19. System.out.println("r2 = " + r3);
  20. }
  21. public static void testNoSeed() {
  22. System.out.println("--------------testNoSeed()--------------");
  23. //创建不带种子的测试Random对象
  24. Random random = new Random();
  25. for (int i = 0; i < 3; i++) {
  26. System.out.println(random.nextInt());
  27. }
  28. }
  29. public static void testSeed1() {
  30. System.out.println("--------------testSeed1()--------------");
  31. //创建带种子的测试Random对象
  32. Random random = new Random(555L);
  33. for (int i = 0; i < 3; i++) {
  34. System.out.println(random.nextInt());
  35. }
  36. }
  37. public static void testSeed2() {
  38. System.out.println("--------------testSeed2()--------------");
  39. //创建带种子的测试Random对象
  40. Random random = new Random();
  41. random.setSeed(555L);
  42. for (int i = 0; i < 3; i++) {
  43. System.out.println(random.nextInt());
  44. }
  45. }
  46. }

运行结果:

  1. --------------test()--------------
  2. r1 = 1227108626582
  3. r3 = 0.5324887850155043
  4. r2 = -368083737
  5. --------------testNoSeed()--------------
  6. 809503475
  7. 1585541532
  8. -645134204
  9. --------------testSeed1()--------------
  10. -1367481220
  11. 292886146
  12. -1462441651
  13. --------------testSeed2()--------------
  14. -1367481220
  15. 292886146
  16. -1462441651
  17. Process finished with exit code 0

通过testSeed1()与testSeed2()方法的结果可以看到,两个打印结果相同,因为他们种子相同,再运行一次,结果还是一样的,这就是带种子随机数的特性。

而不带种子的,每次运行结果都是随机的。

五、综合应用

下面通过最近写的一个随机数工具类来展示用法:

  1. import java.util.Random;
  2. /**
  3. * 随机数、随即字符串工具
  4. */
  5. public class RandomUtils {
  6. public static final String allChar = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
  7. public static final String letterChar = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
  8. public static final String numberChar = "0123456789";
  9. /**
  10. * 返回一个定长的随机字符串(只包含大小写字母、数字)
  11. *
  12. * @param length 随机字符串长度
  13. * @return 随机字符串
  14. */
  15. public static String generateString(int length) {
  16. StringBuffer sb = new StringBuffer();
  17. Random random = new Random();
  18. for (int i = 0; i < length; i++) {
  19. sb.append(allChar.charAt(random.nextInt(allChar.length())));
  20. }
  21. return sb.toString();
  22. }
  23. /**
  24. * 返回一个定长的随机纯字母字符串(只包含大小写字母)
  25. *
  26. * @param length 随机字符串长度
  27. * @return 随机字符串
  28. */
  29. public static String generateMixString(int length) {
  30. StringBuffer sb = new StringBuffer();
  31. Random random = new Random();
  32. for (int i = 0; i < length; i++) {
  33. sb.append(allChar.charAt(random.nextInt(letterChar.length())));
  34. }
  35. return sb.toString();
  36. }
  37. /**
  38. * 返回一个定长的随机纯大写字母字符串(只包含大小写字母)
  39. *
  40. * @param length 随机字符串长度
  41. * @return 随机字符串
  42. */
  43. public static String generateLowerString(int length) {
  44. return generateMixString(length).toLowerCase();
  45. }
  46. /**
  47. * 返回一个定长的随机纯小写字母字符串(只包含大小写字母)
  48. *
  49. * @param length 随机字符串长度
  50. * @return 随机字符串
  51. */
  52. public static String generateUpperString(int length) {
  53. return generateMixString(length).toUpperCase();
  54. }
  55. /**
  56. * 生成一个定长的纯0字符串
  57. *
  58. * @param length 字符串长度
  59. * @return 纯0字符串
  60. */
  61. public static String generateZeroString(int length) {
  62. StringBuffer sb = new StringBuffer();
  63. for (int i = 0; i < length; i++) {
  64. sb.append('0');
  65. }
  66. return sb.toString();
  67. }
  68. /**
  69. * 根据数字生成一个定长的字符串,长度不够前面补0
  70. *
  71. * @param num             数字
  72. * @param fixdlenth 字符串长度
  73. * @return 定长的字符串
  74. */
  75. public static String toFixdLengthString(long num, int fixdlenth) {
  76. StringBuffer sb = new StringBuffer();
  77. String strNum = String.valueOf(num);
  78. if (fixdlenth - strNum.length() >= 0) {
  79. sb.append(generateZeroString(fixdlenth - strNum.length()));
  80. } else {
  81. throw new RuntimeException("将数字" + num + "转化为长度为" + fixdlenth + "的字符串发生异常!");
  82. }
  83. sb.append(strNum);
  84. return sb.toString();
  85. }
  86. /**
  87. * 根据数字生成一个定长的字符串,长度不够前面补0
  88. *
  89. * @param num             数字
  90. * @param fixdlenth 字符串长度
  91. * @return 定长的字符串
  92. */
  93. public static String toFixdLengthString(int num, int fixdlenth) {
  94. StringBuffer sb = new StringBuffer();
  95. String strNum = String.valueOf(num);
  96. if (fixdlenth - strNum.length() >= 0) {
  97. sb.append(generateZeroString(fixdlenth - strNum.length()));
  98. } else {
  99. throw new RuntimeException("将数字" + num + "转化为长度为" + fixdlenth + "的字符串发生异常!");
  100. }
  101. sb.append(strNum);
  102. return sb.toString();
  103. }
  104. public static void main(String[] args) {
  105. System.out.println(generateString(15));
  106. System.out.println(generateMixString(15));
  107. System.out.println(generateLowerString(15));
  108. System.out.println(generateUpperString(15));
  109. System.out.println(generateZeroString(15));
  110. System.out.println(toFixdLengthString(123, 15));
  111. System.out.println(toFixdLengthString(123L, 15));
  112. }
  113. }
  1. import java.util.Random;
  2. /**
  3. * 随机数、随即字符串工具
  4. */
  5. public class RandomUtils {
  6. public static final String allChar = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
  7. public static final String letterChar = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
  8. public static final String numberChar = "0123456789";
  9. /**
  10. * 返回一个定长的随机字符串(只包含大小写字母、数字)
  11. *
  12. * @param length 随机字符串长度
  13. * @return 随机字符串
  14. */
  15. public static String generateString(int length) {
  16. StringBuffer sb = new StringBuffer();
  17. Random random = new Random();
  18. for (int i = 0; i < length; i++) {
  19. sb.append(allChar.charAt(random.nextInt(allChar.length())));
  20. }
  21. return sb.toString();
  22. }
  23. /**
  24. * 返回一个定长的随机纯字母字符串(只包含大小写字母)
  25. *
  26. * @param length 随机字符串长度
  27. * @return 随机字符串
  28. */
  29. public static String generateMixString(int length) {
  30. StringBuffer sb = new StringBuffer();
  31. Random random = new Random();
  32. for (int i = 0; i < length; i++) {
  33. sb.append(allChar.charAt(random.nextInt(letterChar.length())));
  34. }
  35. return sb.toString();
  36. }
  37. /**
  38. * 返回一个定长的随机纯大写字母字符串(只包含大小写字母)
  39. *
  40. * @param length 随机字符串长度
  41. * @return 随机字符串
  42. */
  43. public static String generateLowerString(int length) {
  44. return generateMixString(length).toLowerCase();
  45. }
  46. /**
  47. * 返回一个定长的随机纯小写字母字符串(只包含大小写字母)
  48. *
  49. * @param length 随机字符串长度
  50. * @return 随机字符串
  51. */
  52. public static String generateUpperString(int length) {
  53. return generateMixString(length).toUpperCase();
  54. }
  55. /**
  56. * 生成一个定长的纯0字符串
  57. *
  58. * @param length 字符串长度
  59. * @return 纯0字符串
  60. */
  61. public static String generateZeroString(int length) {
  62. StringBuffer sb = new StringBuffer();
  63. for (int i = 0; i < length; i++) {
  64. sb.append('0');
  65. }
  66. return sb.toString();
  67. }
  68. /**
  69. * 根据数字生成一个定长的字符串,长度不够前面补0
  70. *
  71. * @param num             数字
  72. * @param fixdlenth 字符串长度
  73. * @return 定长的字符串
  74. */
  75. public static String toFixdLengthString(long num, int fixdlenth) {
  76. StringBuffer sb = new StringBuffer();
  77. String strNum = String.valueOf(num);
  78. if (fixdlenth - strNum.length() >= 0) {
  79. sb.append(generateZeroString(fixdlenth - strNum.length()));
  80. } else {
  81. throw new RuntimeException("将数字" + num + "转化为长度为" + fixdlenth + "的字符串发生异常!");
  82. }
  83. sb.append(strNum);
  84. return sb.toString();
  85. }
  86. /**
  87. * 根据数字生成一个定长的字符串,长度不够前面补0
  88. *
  89. * @param num             数字
  90. * @param fixdlenth 字符串长度
  91. * @return 定长的字符串
  92. */
  93. public static String toFixdLengthString(int num, int fixdlenth) {
  94. StringBuffer sb = new StringBuffer();
  95. String strNum = String.valueOf(num);
  96. if (fixdlenth - strNum.length() >= 0) {
  97. sb.append(generateZeroString(fixdlenth - strNum.length()));
  98. } else {
  99. throw new RuntimeException("将数字" + num + "转化为长度为" + fixdlenth + "的字符串发生异常!");
  100. }
  101. sb.append(strNum);
  102. return sb.toString();
  103. }
  104. public static void main(String[] args) {
  105. System.out.println(generateString(15));
  106. System.out.println(generateMixString(15));
  107. System.out.println(generateLowerString(15));
  108. System.out.println(generateUpperString(15));
  109. System.out.println(generateZeroString(15));
  110. System.out.println(toFixdLengthString(123, 15));
  111. System.out.println(toFixdLengthString(123L, 15));
  112. }
  113. }

运行结果:

    1. vWMBPiNbzfGCpHG
    2. 23hyraHdJkKPwMv
    3. tigowetbwkm1nde
    4. BPZ1KNEJPHB115N
    5. 000000000000000
    6. 000000000000123
    7. 000000000000123
    8. Process finished with exit code 0

java产生随机数的三种方式的更多相关文章

  1. Java生成随机数的三种方式

    package cn.zytao.taosir.random; import java.util.Random; public class RandomDemo { private static In ...

  2. java产生随机数的几种方式

    java产生随机数的几种方式 一.在j2se里我们可以使用Math.random()方法来产生一个随机数,这个产生的随机数是0-1之间的一个double,我们可以把他乘以一定的数,比如说乘以100,他 ...

  3. java 获取随机数的三种方法

    方法1(数据类型)(最小值+Math.random()*(最大值-最小值+1))例:(int)(1+Math.random()*(10-1+1))从1到10的int型随数 方法2获得随机数for (i ...

  4. java 获取时间戳的三种方式

      java 获取时间戳的三种方式 CreationTime--2018年7月13日16点29分 Author:Marydon 1.实现方式 方式一:推荐使用 System.currentTimeMi ...

  5. 如何实现有返回值的多线程 JAVA多线程实现的三种方式

    可返回值的任务必须实现Callable接口,类似的,无返回值的任务必须Runnable接口.执行Callable任务后,可以获取一个Future的对象,在该对象上调用get就可以获取到Callable ...

  6. Java实现线程的三种方式和区别

    Java实现线程的三种方式和区别 Java实现线程的三种方式: 继承Thread 实现Runnable接口 实现Callable接口 区别: 第一种方式继承Thread就不能继承其他类了,后面两种可以 ...

  7. [OpenSource]浅谈.Net和Java互相调用的三种方式

    在很多的大型系统开发中,开发工具往往不限制于同一种开发语言,而是会使用多种开发语言的混合型开发.目前Java和.Net都声称自己占85%的市场份额,不管谁对谁错,Java和.Net是目前应用开发的两个 ...

  8. 浅谈.Net和Java互相调用的三种方式

    在很多的大型系统开发中,开发工具往往不限制于同一种开发语言,而是会使用多种开发语言的混合型开发.目前Java和.Net都声称自己占85%的市场份 额,不管谁对谁错,Java和.Net是目前应用开发的两 ...

  9. Java并发编程:Java创建线程的三种方式

    目录 引言 创建线程的三种方式 一.继承Thread类 二.实现Runnable接口 三.使用Callable和Future创建线程 三种方式的对比 引言 在日常开发工作中,多线程开发可以说是必备技能 ...

随机推荐

  1. C++ 容器(一):顺序容器简介

    C++提供了使用抽象进行高效编程的方式,标准库中定义了许多容器类以及一系列泛型函数,使程序员可以更加简洁.抽象和有效地编写程序,其中包括:顺序容器,关联容器和泛型算法.本文将简介顺序容器(vector ...

  2. 洛谷 P1754 球迷购票问题

    P1754 球迷购票问题 题目背景 盛况空前的足球赛即将举行.球赛门票售票处排起了球迷购票长龙. 按售票处规定,每位购票者限购一张门票,且每张票售价为50元.在排成长龙的球迷中有N个人手持面值50元的 ...

  3. View 和 ViewGroup 的 hasFocusable

    在 android 中.焦点的获取和事件几乎相同,有一个分发机制.一般来说View 树上上层节点的 ViewGroup 比底层节点的 View 有更高的优先级获取焦点.这体如今 ViewGroup 有 ...

  4. [Python] Histograms for analysis Daily return

    A histogram is an accurate representation of the distribution of numerical data. Y axis is the occur ...

  5. 三:redis的List类型相关操作

    </pre><pre name="code" class="php" style="font-size: 14px;"&g ...

  6. BZOJ 2982 combination Lucas定理

    题目大意:发上来就过不了审核了--总之大意就是求C(n,m) mod 10007 m,n∈[1,2*10^8] 卢卡斯定理:C(n,m)=C(n%p,m%p)*C(n/p,m/p) mod p 要求p ...

  7. ZOJ 2588 Burning Bridges(无向连通图求割边)

    题目地址:ZOJ 2588 由于数组开小了而TLE了..这题就是一个求无向连通图最小割边.仅仅要推断dfn[u]是否<low[v],由于low指的当前所能回到的祖先的最小标号,增加low[v]大 ...

  8. Sam做题记录

    Sam做题记录 Hihocoder 后缀自动机二·重复旋律5 求一个串中本质不同的子串数 显然,答案是 \(\sum len[i]-len[fa[i]]\) Hihocoder 后缀自动机三·重复旋律 ...

  9. ASP.net Web API允许跨域访问解决办法

    来源 http://blog.csdn.net/wxg_kingwolfmsncn/article/details/48545099 遇到此跨域访问问题,解决办法如下:   方法一:   1. 在we ...

  10. 使用iframe在手机中嵌套页面

    使用iframe嵌套网页 <iframe id="show-iframes" frameborder="0" name="showHere&qu ...