歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux編程 >> Linux編程

Java中random隨機函數認識理解

random()是偽隨機數生成器,因為的它的隨機數生成都是和seed種子相關的,只要種子相同生成的隨機數都是相同的,在沒有指定種子的情況下會根據當前時間生成一個種子參數。

實際上Random是一種偽隨機數,相同的種子產生相同的序列(注意不是相同數值)。
為什麼說是生成相同的序列,這裡要理解下構造函數設定種子後(不管是自己指定的還是,系統默認生成的)隨機數是怎樣生成的:

首先nextInt()函數會根據當前的seed生成一個隨機後,然後把生成的隨機數賦值給seed,繼續生成隨機數,一直這樣執行下去。

所以好好理解下面兩段代碼

public static void main(String[] args) {

             
    for (int i=0;i<10;i++){
    Random r = new Random(10);
    data = r.nextInt(10);
              System.out.print(rand);   
    System.out.print(" ");
    }
   
    }

生成的10個數都是一樣的

public static void main(String[] args) {

            Random r = new Random(10);
            for (int i=0;i<10;i++){
            data = r.nextInt(10);
                      System.out.print(rand);
            System.out.print(" ");
            }
        }

上面這段代碼生成的10個數都不一樣,但是再次執行的時候生成的10個數序列和上次執行for循環生成的序列是一樣的,這點就是上面那句的意思
random()默認生成種子的原理是一樣的,但是如果把上面換成random()的話,執行多次for循環生成的隨機數都會不一樣,因為每次執行的時候時間不一樣了 所以默認的種子也就不同了,由此可知,random()隨機數生成的關鍵是要有一個的真正隨機的種子。

Copyright © Linux教程網 All Rights Reserved