


Eine Einführung in die Methoden und Prinzipien der java.util.Random-Implementierung
Die Klasse java.util.Random in der Java-Utility-Klassenbibliothek bietet Methoden zum Generieren verschiedener Arten von Zufallszahlen. Der folgende Artikel stellt hauptsächlich relevante Informationen zum Implementierungsprinzip von java.util.Random vor Sehr detailliert, Freunde in Not können sich darauf beziehen.
Übersicht
java.util.Random kann Zufallszahlen der Typen int, long, float, double und Goussian generieren. Dies ist auch der größte Unterschied zur Methode Random() in java.lang.Math, die nur Zufallszahlen vom doppelten Typ generiert.
Instanzen dieser Klasse werden verwendet, um einen Strom von Pseudozufallszahlen zu generieren. Diese Klasse verwendet einen 48-Bit-Seed, der durch eine lineare Kongruenzformel modifiziert wird. Wenn zwei Instanzen von Random mit demselben Startwert erstellt werden, generieren sie dieselbe Zahlenfolge und geben sie zurück, indem sie für jede Instanz dieselbe Folge von Methodenaufrufen ausführen.
Beispiel
public class RandomTest { public static void main(String[] args) { testRandom(); System.out.println("---------------------"); testRandom(); System.out.println("---------------------"); testRandom(); } public static void testRandom(){ Random random = new Random(1); for(int i=0; i<5; i++){ System.out.print(random.nextInt()+"\t"); } System.out.println(""); } }
Ausgabeergebnis:
Aus den Ergebnissen haben wir herausgefunden, dass die Folge der erhaltenen Zufallszahlen konsistent ist, solange die Samen gleich sind. Es handelt sich um eine Implementierung von Pseudozufallszahlen, nicht von echten Zufallszahlen.
Zufällige Quellcode-Analyse
Zufällige Klassenstruktur
class Random implements java.io.Serializable { private final AtomicLong seed; private static final long multiplier = 0x5DEECE66DL; private static final long addend = 0xBL; private static final long mask = (1L << 48) - 1; private static final AtomicLong seedUniquifier = new AtomicLong(8682522807148012L);
Da sind Referenzen Die Konstruktionsmethode
public Random(long seed) { if (getClass() == Random.class) this.seed = new AtomicLong(initialScramble(seed)); else { // subclass might have overriden setSeed this.seed = new AtomicLong(); setSeed(seed); } } private static long initialScramble(long seed) { return (seed ^ multiplier) & mask; }
generiert Zufallszahlen durch Übergabe eines Startwerts. Aus dem obigen Beispiel geht hervor, dass die Zufallszahlenfolge von demselben Startwert generiert wird ist bei jeder Verwendung gleich. Wenn Sie unterschiedliche Sequenzen generieren möchten, können Sie jedes Mal nur einen anderen Startwert übergeben.
Konstruktionsmethode ohne Parameter
public Random() { this(seedUniquifier() ^ System.nanoTime()); } private static long seedUniquifier() { // L'Ecuyer, "Tables of Linear Congruential Generators of // Different Sizes and Good Lattice Structure", 1999 for (;;) { long current = seedUniquifier.get(); long next = current * 181783497276652981L; if (seedUniquifier.compareAndSet(current, next)) return next; } }
Durch den Quellcode entdeckt, sind die Parameter- weniger Konstruktionsmethode, Es generiert automatisch einen Startwert für uns und verwendet die CAS-Spin-Methode, um sicherzustellen, dass der erhaltene Startwert jedes Mal unterschiedlich ist, wodurch sichergestellt wird, dass die jedes Mal erhaltene Zufallssequenz new Random()
inkonsistent ist.
nextInt()-Methode: Int-Zufallszahl abrufen
public int nextInt() { return next(32); } protected int next(int bits) { long oldseed, nextseed; AtomicLong seed = this.seed; do { oldseed = seed.get(); nextseed = (oldseed * multiplier + addend) & mask; } while (!seed.compareAndSet(oldseed, nextseed)); return (int)(nextseed >>> (48 - bits)); }
Aus dem Code können wir Es wurde festgestellt, dass die generierte Anzahl jedes Mal mit einem festen Algorithmus generiert wird, solange der Startwert bestimmt ist. Solange der Startwert bestimmt ist, ist die generierte Reihenfolge jedes Mal festgelegt.
Jedes Mal, wenn der Seed aktualisiert wird, wird CAS verwendet, um ihn zu aktualisieren. In einer Umgebung mit hoher Parallelität ist die Leistung ein Problem.
Sicherheitsprobleme
Stellen Sie sich vor, es handelt sich um eine Lotterieplattform. Solange der Startwert festgelegt ist, ist die generierte Sequenz jedes Mal dieselbe Zeit . Auf diese Weise kann diese Lücke genutzt werden, um die Zahlen der nächsten Lottoziehung vorherzusagen, was von manchen Menschen leicht ausgenutzt werden kann.
jdk empfiehlt, dass Sie versuchen, SecureRandom zum Generieren von Zufallszahlen zu verwenden.
SecureRandom
SecureRandom ist ein starker Zufallszahlengenerator. Die Hauptanwendungsszenarien sind: Datennummern für Sicherheitszwecke, beispielsweise zum Generieren von Geheimnissen. Schlüssel oder Sitzungs-ID. Im obigen Artikel „Sicherheit von Pseudozufallszahlen“ wurden die Sicherheitsprobleme schwacher Zufallszahlengeneratoren für jedermann dargelegt. Die Verwendung starker Zufallszahlengeneratoren wie SecureRandom verringert das Risiko, dass etwas schief geht.
Um hochfeste Zufallszahlen zu generieren, gibt es zwei wichtige Faktoren: Startwert und Algorithmus. Es kann viele Algorithmen geben, und normalerweise ist die Auswahl des Startwerts ein sehr kritischer Faktor. Beispielsweise ist der Startwert von Random System.currentTimeMillis(), sodass seine Zufallszahlen vorhersehbare und schwache Pseudozufallszahlen sind.
Die Idee, starke Pseudozufallszahlen zu generieren: Sammeln Sie verschiedene Computerinformationen, Tastatureingabezeit, Speichernutzungsstatus, freien Speicherplatz auf der Festplatte, E/A-Verzögerung, Anzahl der Prozesse, Anzahl der Threads und andere Informationen, CPU-Uhr, um eine annähernd zufällige Zahl zu erhalten Die Samen erreichen hauptsächlich Unvorhersehbarkeit.
Um es einfach auszudrücken: Verwenden Sie einen Verschlüsselungsalgorithmus, um einen sehr langen Zufallsstartwert zu generieren, sodass Sie den Startwert nicht erraten und daher die Zufallssequenznummer nicht ableiten können.
Zufällige Leistungsprobleme
Aus dem Random-Quellcode haben wir herausgefunden, dass CAS verwendet wird, um den Startwert jedes Mal zu aktualisieren, wenn eine Zufallszahl erhalten wird. Wert. Auf diese Weise kommt es in einer Umgebung mit hoher Parallelität zu einer großen Anzahl von CAS-Wiederholungsversuchen, was zu Leistungseinbußen führt. Zu diesem Zeitpunkt wird empfohlen, die ThreadLocalRandom-Klasse zum Generieren von Zufallszahlen zu verwenden.
ThreadLocalRandom-Implementierungsprinzip
Thread-Klasse
In der Thread-Klasse gibt es eine threadLocalRandomSeed-Eigenschaft.
ThreadLocalRandom-Struktur
Die SEED-Variable ist der Offset von threadLocalRandomSeed im Thread-Objekt.
ThreadLocalRandom.nextSeed()-Methode
Anhand dieser Methode stellen wir fest, dass der Startwert jedes Threads in In gespeichert ist die threadLocalRandomSeed-Eigenschaft des Thread-Objekts.
Fazit
Da die Seeds in ThreadLocalRandom in Thread-Objekten gespeichert werden, wird CAS nicht verwendet, um eine hohe Parallelität beim Erwerb von Random-Objekten sicherzustellen. Die jedes Mal erhaltenen Werte sind inkonsistent.
Jeder Thread verwaltet seinen eigenen Startwert. Wenn jeder Thread Zufallszahlen erhalten muss, erhält er den Startwert des aktuellen Threads vom aktuellen Thread-Objekt und erhält so die Leistung erheblich.
Das obige ist der detaillierte Inhalt vonEine Einführung in die Methoden und Prinzipien der java.util.Random-Implementierung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



WeChat ist eines der gängigen Chat-Tools. Über WeChat können wir neue Freunde treffen, alte Freunde kontaktieren und die Freundschaft zwischen Freunden pflegen. So wie es kein Bankett gibt, das nie endet, kommt es zwangsläufig zu Meinungsverschiedenheiten, wenn Menschen miteinander auskommen. Wenn eine Person Ihre Stimmung stark beeinflusst oder Sie feststellen, dass Ihre Ansichten nicht übereinstimmen, wenn Sie miteinander auskommen, und Sie nicht mehr kommunizieren können, müssen wir möglicherweise WeChat-Freunde löschen. Wie lösche ich WeChat-Freunde? Der erste Schritt zum Löschen von WeChat-Freunden: Tippen Sie auf der Hauptoberfläche von WeChat auf [Adressbuch]; der zweite Schritt: Klicken Sie auf den Freund, den Sie löschen möchten, und geben Sie im oberen Schritt [Details] ein rechte Ecke; Schritt 4: Klicken Sie unten auf [Löschen]; Schritt 5: Nachdem Sie die Eingabeaufforderungen der Seite verstanden haben, klicken Sie auf [Kontakt löschen].

Tomato Novel ist eine sehr beliebte Roman-Lesesoftware. Jeder Roman und Comic ist sehr interessant und möchte auch Romane schreiben Also, wie schreiben wir den Roman darin? Meine Freunde wissen es nicht, also lasst uns gemeinsam auf diese Seite gehen und uns eine Einführung zum Schreiben eines Romans ansehen. Teilen Sie das Tomato-Roman-Tutorial zum Schreiben eines Romans. 1. Öffnen Sie zunächst die kostenlose Tomato-Roman-App auf Ihrem Mobiltelefon und klicken Sie auf „Personal Center – Writer Center“. 2. Gehen Sie zur Seite „Tomato Writer Assistant“ – klicken Sie auf „Neues Buch erstellen“. am Ende des Romans.

Colorful-Motherboards erfreuen sich auf dem chinesischen Inlandsmarkt großer Beliebtheit und Marktanteil, aber einige Benutzer von Colorful-Motherboards wissen immer noch nicht, wie sie im BIOS Einstellungen vornehmen sollen? Als Reaktion auf diese Situation hat Ihnen der Herausgeber speziell zwei Methoden zum Aufrufen des farbenfrohen Motherboard-BIOS vorgestellt. Kommen Sie und probieren Sie es aus! Methode 1: Verwenden Sie die U-Disk-Start-Tastenkombination, um das U-Disk-Installationssystem direkt aufzurufen. Die Tastenkombination für das Colorful-Motherboard zum Starten der U-Disk ist zunächst ESC oder F11, um ein Black zu erstellen Wenn Sie den Startbildschirm sehen, drücken Sie kontinuierlich die ESC- oder F11-Taste auf der Tastatur, um ein Fenster zur Auswahl der Startelementsequenz aufzurufen. Bewegen Sie den Cursor an die Stelle, an der „USB“ angezeigt wird " wird angezeigt, und dann

Leider löschen Menschen aus bestimmten Gründen oft versehentlich bestimmte Kontakte. WeChat ist eine weit verbreitete soziale Software. Um Benutzern bei der Lösung dieses Problems zu helfen, wird in diesem Artikel erläutert, wie gelöschte Kontakte auf einfache Weise wiederhergestellt werden können. 1. Verstehen Sie den WeChat-Kontaktlöschmechanismus. Dies bietet uns die Möglichkeit, gelöschte Kontakte wiederherzustellen. Der Kontaktlöschmechanismus in WeChat entfernt sie aus dem Adressbuch, löscht sie jedoch nicht vollständig. 2. Nutzen Sie die integrierte „Kontaktbuch-Wiederherstellung“-Funktion von WeChat, um Zeit und Energie zu sparen. Mit dieser Funktion können Benutzer schnell gelöschte Kontakte wiederherstellen. 3. Rufen Sie die WeChat-Einstellungsseite auf und klicken Sie auf die untere rechte Ecke, öffnen Sie die WeChat-Anwendung „Me“ und klicken Sie auf das Einstellungssymbol in der oberen rechten Ecke, um die Einstellungsseite aufzurufen.

Das Festlegen der Schriftgröße ist zu einer wichtigen Personalisierungsanforderung geworden, da Mobiltelefone zu einem wichtigen Werkzeug im täglichen Leben der Menschen geworden sind. Um den Bedürfnissen verschiedener Benutzer gerecht zu werden, wird in diesem Artikel erläutert, wie Sie das Nutzungserlebnis Ihres Mobiltelefons verbessern und die Schriftgröße des Mobiltelefons durch einfache Vorgänge anpassen können. Warum müssen Sie die Schriftgröße Ihres Mobiltelefons anpassen? Durch Anpassen der Schriftgröße kann der Text klarer und leichter lesbar werden. Geeignet für die Lesebedürfnisse von Benutzern unterschiedlichen Alters. Praktisch für Benutzer mit Sehbehinderung, die Schriftgröße zu verwenden Einstellungsfunktion des Mobiltelefonsystems – So rufen Sie die Systemeinstellungsoberfläche auf – Suchen und geben Sie die Option „Anzeige“ in der Einstellungsoberfläche ein – suchen Sie die Option „Schriftgröße“ und passen Sie sie mit einem Drittanbieter an Anwendung – Laden Sie eine Anwendung herunter und installieren Sie sie, die die Anpassung der Schriftgröße unterstützt – öffnen Sie die Anwendung und rufen Sie die entsprechende Einstellungsoberfläche auf – je nach Person

Eine Zusammenfassung, wie Sie Win11-Administratorrechte erhalten. Im Betriebssystem Windows 11 sind Administratorrechte eine der sehr wichtigen Berechtigungen, die es Benutzern ermöglichen, verschiedene Vorgänge auf dem System auszuführen. Manchmal benötigen wir möglicherweise Administratorrechte, um einige Vorgänge abzuschließen, z. B. die Installation von Software, das Ändern von Systemeinstellungen usw. Im Folgenden werden einige Methoden zum Erhalten von Win11-Administratorrechten zusammengefasst. Ich hoffe, dass sie Ihnen helfen können. 1. Verwenden Sie Tastenkombinationen. Im Windows 11-System können Sie die Eingabeaufforderung schnell über Tastenkombinationen öffnen.

Mobile Spiele sind mit der Entwicklung der Technologie zu einem festen Bestandteil des Lebens der Menschen geworden. Mit seinem niedlichen Drachenei-Bild und dem interessanten Schlüpfvorgang hat es die Aufmerksamkeit vieler Spieler auf sich gezogen, und eines der Spiele, das viel Aufmerksamkeit erregt hat, ist die mobile Version von Dragon Egg. Um den Spielern dabei zu helfen, ihre eigenen Drachen im Spiel besser zu kultivieren und zu züchten, erfahren Sie in diesem Artikel, wie Sie Dracheneier in der mobilen Version ausbrüten. 1. Wählen Sie den geeigneten Drachenei-Typ aus, der Ihnen gefällt und zu Ihnen passt, basierend auf den verschiedenen Arten von Drachenei-Attributen und -Fähigkeiten, die im Spiel zur Verfügung stehen. 2. Verbessern Sie die Stufe der Brutmaschine, indem Sie Aufgaben erledigen und Requisiten sammeln. Die Stufe der Brutmaschine bestimmt die Schlüpfgeschwindigkeit und die Erfolgsquote beim Schlüpfen. 3. Sammeln Sie die Ressourcen, die die Spieler zum Schlüpfen benötigen

Ausführliche Erläuterung der Oracle-Versionsabfragemethode Oracle ist eines der beliebtesten relationalen Datenbankverwaltungssysteme weltweit. Es bietet umfangreiche Funktionen und leistungsstarke Leistung und wird häufig in Unternehmen eingesetzt. Im Prozess der Datenbankverwaltung und -entwicklung ist es sehr wichtig, die Version der Oracle-Datenbank zu verstehen. In diesem Artikel wird detailliert beschrieben, wie die Versionsinformationen der Oracle-Datenbank abgefragt werden, und es werden spezifische Codebeispiele angegeben. Fragen Sie die Datenbankversion der SQL-Anweisung in der Oracle-Datenbank ab, indem Sie eine einfache SQL-Anweisung ausführen
