Heim >Java >javaLernprogramm >Drei Möglichkeiten, Zufallszahlen in Java zu generieren
Die Generierung von Zufallszahlen wird in einigen Codes sehr häufig verwendet und ist auch etwas, das wir beherrschen müssen. Es gibt drei Hauptmethoden zum Generieren von Zufallszahlen in Java:
Die erste: new Random()
Der zweite Typ: Math.random()
Der dritte Typ: currentTimeMillis()
Der erste Typ erfordert die Hilfe von java.util .Random-Klasse zum Generieren eines Zufallszahlengenerators , der auch am häufigsten verwendet wird. Es gibt zwei Konstruktoren, Random() und Random(long Seed). Der erste verwendet die aktuelle Zeit als Standard-Seed und der zweite verwendet den angegebenen Seed-Wert. Nach der Generierung werden mithilfe unterschiedlicher Anweisungen unterschiedliche Arten von Zahlen generiert.
Der Startwert ist der erste Wert, der zum Generieren von Zufallszahlen verwendet wird. Der Mechanismus besteht darin, den Wert dieses Startwerts über eine Funktion in einen bestimmten Punkt im Zufallszahlenraum umzuwandeln und die generierten Zufallszahlen gleichmäßig zu verteilen Raum. Die in der Zukunft generierten Zufallszahlen beziehen sich auf die vorherige Zufallszahl. Nehmen Sie Code als Beispiel.
public static void main(String[] args) { Random r = new Random(1); for(int i=0 ; i<5 ; i++) { int ran1 = r.nextInt(100); System.out.println(ran1); } }
Die fünf von meinem Compiler generierten Zahlen sind alle 85,88,47,13,54. Wenn Random r = new Random() verwendet wird, werden die generierten Zufallszahlen unterschiedlich sein des Samens.
Und der von der zweiten Methode zurückgegebene Wert ist ein Double-Wert von [0,0,1,0). Da Double-Zahlen eine hohe Genauigkeit haben, können sie bis zu einem gewissen Grad als Zufallszahlen betrachtet werden. Durch die Verwendung von (int) zur Typkonvertierung können Sie eine ganzzahlige Zufallszahl erhalten. Der Code lautet wie folgt.
public static void main(String[] args) { int max=100,min=1; int ran2 = (int) (Math.random()*(max-min)+min); System.out.println(ran2); }
Was die dritte Methode betrifft, so wird sie zwar nicht häufig verwendet, ist aber dennoch eine Idee. Die Methode gibt eine lange Anzahl von Millisekunden von 0:00:00 am 1. Januar 1970 (dies bezieht sich auf das UNIX-System) bis zur Gegenwart zurück. Nach der Modulo-Erfassung kann eine Zufallszahl innerhalb des erforderlichen Bereichs ermittelt werden .
public static void main(String[] args) { int max=100,min=1; long randomNum = System.currentTimeMillis(); int ran3 = (int) (randomNum%(max-min)+min); System.out.println(ran3); }
Das obige ist der detaillierte Inhalt vonDrei Möglichkeiten, Zufallszahlen in Java zu generieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!