www.mikrocontroller.net

Forum: PC-Programmierung Java: synchronized deutlich langsamer


Autor: Maxim (Gast)
Datum:
Angehängte Dateien:

Bewertung
0 lesenswert
nicht lesenswert
Hab zu Testzwecken ein kleines Programm geschrieben:
Es gibt zwei Klassen, Erzeuger und Verbraucher, die von Thread 
abgeleitet sind. Zusätzlich gibt es eine Klasse Kontainer, welche ein 
Integer-Array und entsprechende get-/set-Methoden enthält.
Von jeder Klasse gibt es ein Objekt. Der Erzeuger speichert in einer 
Endlosschleife ständig neue Werte in Kontainer ab, der Verbraucher holt 
sie ebenfalls in einer Endlosschleife gleichzeitig von dort und gibt sie 
in die Konsole aus.

Kann es bei diesem Szenario zu Problemen führen? Ein Deadlock ist ja 
nicht möglich, da beide Objekte (Erzeuger und Verbraucher) nicht 
aufeinander angewiesen sind. Welche Probleme könnte es sonst geben?

Vorsichtshalber habe ich die get-/set-Methoden als synchronized 
gekennzeichnet. Habe dann aber festgestellt, dass die Geschwindigkeit, 
mit der die Zahlen erzeugt und ausgegeben werden, mindestens um den 
Faktor 100 (!) reduziert wurde.

Autor: Jürgen (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Faktor 100 ist normal in dieser Situation, deine Threads streiten sich 
hauptsächlich um den Zugriff.

Nur 10x langsamer sind java.util.concurrent.atomic.AtomicXYZ.

Überhaupt solltest du mal in java.util.concurrent reinschauen.

volatile gibt es auch noch.

Wenn man nichts bzgl. Nebenläufigkeit macht, können die Threads im 
Prinzip in ihren eigenen lokalen Speicherbereichen arbeiten und nichts 
voneinander merken. Oder sie sehen die Zugriffe in unterschiedlicher 
Reihenfolge.

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.