Frage zu Nebenläufigkeit

Foermchen82

Top Contributor
Folgendes Szenario:

Eine Applikation beinhalten einen Service, der singelton ist.

Zwei Threads greifen gleichzeitig auf die gleiche Methode zu. In dem Service gibt es keine globalen Variablen außer DAOs.

Jeder Zugriff auf die Methode liefert Eingangsparameter, für die Berechnungen angestellt werden.

Kann es hierbei zu Kollisionen der Threads kommen, oder Arbeitet jede Methode für sich?

Danke im voraus
 
G

Gast2

Gast
Solange da nichts weiter synchonsiert werden muss können die Threads gleichzeitig die Methode im Singleton aufrufen. Wenn die Methode wirklich nur lokale Variablen nutzt sollte da kein weiteres Problem mit bestehen.
 

tfa

Top Contributor
Was ist mit den DAOs? Sind das Membervariablen der Service-Klasse? Wenn die dann nicht threadsicher sind, knallt es früher oder später.
 
M

maki

Gast
Kann es hierbei zu Kollisionen der Threads kommen, oder Arbeitet jede Methode für sich?
ganz klar: Vielleicht

Programme werden nicht automatisch oder gar zufällig Threadsicher, entweder sie sind bereits so geschrieben, oder du sitzt auf einer Zeitbombe.
Solche fehler sind übrigens schwer nachzustellen.
 

Andi_CH

Top Contributor
Ja das die DAOs thread sicher sein müssen ist klar.

Aber die Methoden an sich arbeiten dann schon separat, oder?

Was heisst "separat"???

Es ist ein und derselbe Code der durchlaufen wird.
Natürlich benutzt jede "Instanz" des Codes das Stacksegment des aufrufenden Kontextes
Statische Variablen sind aber nur einmal vorhanden
Objekte die über Referenzen angesprochen werden sind möglicherweise auch nur einmal vorhanden
( -> singleton -> ist in dem Fall ja klar)


Vielleicht muss ich es so sagen:
Methoden arbeiten gar nicht - es sind die Threads die arbeiten und die arbeiten den Code ein und derselben Methode ab - aber es sind zwei Threads

Hm - ob das klarer ist???:L

Wolltest du das wissen? Wenn nein, habe ich dich falsch verstanden.
 

Tente

Mitglied
Wenn du die gleiche Methode zur gleichen zeit aus dem gleichen Objekt aufrufst ist das eine Kollision... NIIIIE GUT. außer bei gettern, da kannste drauf scheißen. liefern ja nur n wert. aber wenn du methode aufrufst die berechnet, muss die threadsicher sein! Allein der Zugriff über singleton auf die Instanz kann zur Kollision führen. Lies mal ne Runde über das Schlüsselwort "volatile"...
 
S

SlaterB

Gast
> aber wenn du methode aufrufst die berechnet, muss die threadsicher sein!
'ne Methode die berechnet' gegenüber getter ist ja recht ungenau,
solange eine Methode keine statischen/Klassenatttribute benutzt kann sie 10 Min. lang mit lokalen Variablen rechnen, da stören sich mehrere Aufrufe nicht gegenseitig

Collections.sort() ist z.B. eine anschauliche Methode die jede Menge rechnet udn nicht synchronisiert werden muss
 

Foermchen82

Top Contributor
Machen wir mal ein Beispiel:

die Methode soll in einer for-schleife Zahlen mit sich selbst multiplizieren. Das ganze 10 mal. und die eigentliche Zahl kommt als Aufrufparameter in die Methode. Alles mit lokalen Variablen.

Jetzt greifen 2 Threads gleichzeitig auf die Methode des Singeltons zu.

Was nun? Ist das ein Problem, oder laufen die Berechnungen korrekt ab?
 

tfa

Top Contributor
Dann hast du ja keine Daten, auf die konkurierend zugegriffen wird.
Wenn alle Variablen lokal oder immutable sind, ist eine Methode threadsicher.
 

Foermchen82

Top Contributor
richtig. die einzige Konkurrenz ist, dass es die gleiche Methode ist. Also ist sowas unkritisch, richtig? Ich muss halt nur sicherstellen, dass ich keine globalen variablen verwende, und wenn doch muss der zugriff threadsave sein.
 

hdi

Top Contributor
Jeder Thread hat seinen eigenen Stack mit lokalen Variablen, und wie tfa schon sagte ist dein Beispiel also threadsafe.

Aber Vorsicht: Falls es sich bei den lokalen Variablen um welche von einem komplexen Datentyp handelt, und du per Punkt-Notation derefernzierst, kann es wieder krachen, insofern zwei Threads die selbe Referenz nutzen (was zB der Fall wäre wenn die selbe Variable von beiden Threads als Parameter in die Methode übergeben wird). Denn durch die Dereferenzierung schaffst du dir das eigentliche Objekt aus dem Heap ran, und im Gegensatz zu Stacks teilen sich alle Threads einen einzigen Heap! Dann musst du auf diese Variable wieder synchronisieren, obwohl sie lokal ist!
 
Zuletzt bearbeitet:
S

SlaterB

Gast
> Also ist sowas unkritisch, richtig? Ich muss halt nur sicherstellen, dass ich keine globalen variablen verwende,

wenn die Methode intern sauber ist, ist eine unvermeidbare Gefahr dann noch die Parameter von außen,
je nachdem wie intensiv man mit denen interagieren muss kann es fatal enden, wenn eben auf diesen externen Daten zwei Threads gleichzeitig arbeiten,

aber das kann überall im Programm passieren, nicht nur in dieser Methode,
nur als Hinweis dass eine Methode an sich nicht immer restlos ohne Fehlermöglichkeit besteht,

bestenfalls werden die externen Daten kopiert wie es Collections.sort() macht (wobei eher aus anderen Gründen),
aber auch der kurze Kopiervorgang kann unsicher sein und nicht immer ist das möglich/praktikabel
 

Foermchen82

Top Contributor
Ok, ich weiß definitiv, dass die Eingabeparameter nicht in mehreren Threads verwendet werden. Aber der Hinweis ist gut. danke.

Also sehe ich zu, dass um die Methode herum alles sauber ist und thread-safe und die Methode selbst nur lokale Parameter verwendet.

Danke an alle
 

hdi

Top Contributor
Ok, ich weiß definitiv, dass die Eingabeparameter nicht in mehreren Threads verwendet werden

Wahrscheinlich hast du mich schon richtig verstanden, aber ich will sicher gehen: Es kann jetzt nicht nur an den Eingabeparametern liegen, sondern generell daran dass du mit den selben Objekten arbeitest:

Java:
void doStuff(int i){
    Database.getCurrentObject().edit();
}
Thread 1:
doStuff(5);

Thread 2:
doStuff(20);

...wenn die edit-Methode des current object nicht synchronisiert ist, kracht's! Schon klar oder.. Hat alles nix mit lokalen/globalen oder Parameter-Variablen zu tun..
 

Foermchen82

Top Contributor
Wahrscheinlich hast du mich schon richtig verstanden, aber ich will sicher gehen: Es kann jetzt nicht nur an den Eingabeparametern liegen, sondern generell daran dass du mit den selben Objekten arbeitest:

Java:
void doStuff(int i){
    Database.getCurrentObject().edit();
}


...wenn die edit-Methode des current object nicht synchronisiert ist, kracht's! Schon klar oder.. Hat alles nix mit lokalen/globalen oder Parameter-Variablen zu tun..


Ja das ist mir klar. Ich wollte jetzt nicht alle Möglichkeiten eines globalen Zugriffs aufführen *g*
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
KonradN Mal eine Frage zu Binary Serialization Allgemeine Java-Themen 15
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
H Frage regex greater than less than Allgemeine Java-Themen 7
berserkerdq2 Frage zu IntelliJ und JavaFX Allgemeine Java-Themen 1
W Timer Konzept-Frage Allgemeine Java-Themen 16
T Eine Frage des Designs Allgemeine Java-Themen 2
C Frage zu eigenem TableCellRenderer Allgemeine Java-Themen 11
C Programmvorstellung & Frage zum Thema Geschäftsform Allgemeine Java-Themen 51
J Frage zu System.getproperties. Allgemeine Java-Themen 60
molat100 wie kann man die Frage beantworten Allgemeine Java-Themen 1
pkm Frage zur Präzision von Calendar.WEEK_OF_YEAR Allgemeine Java-Themen 12
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
pkm Frage nach eventuellem syntaktischen Zucker bei der Konkatenation von ArrayLists Allgemeine Java-Themen 4
M Frage-Antwortspiel wie Wer wird Millionär Allgemeine Java-Themen 1
F Frage zu System.in Allgemeine Java-Themen 3
marcooooo Frage zum Beispiel im Anhang Allgemeine Java-Themen 16
T Meine Frage lautet wie ich 2 CSV Dateien miteinander in Java verbinde und Spalten die zueinander gehören durch den gleichen Key zusammen ausgebe? Allgemeine Java-Themen 5
S Noch eine Design-Frage zu Setter Allgemeine Java-Themen 6
B For-Loop Frage Allgemeine Java-Themen 21
L Java frage Allgemeine Java-Themen 3
bueseb84 Frage zu Mock und UpperBound Allgemeine Java-Themen 2
M Frage zum Konstruktor Allgemeine Java-Themen 2
W Best Practice Frage zur Umsetzung MVC Allgemeine Java-Themen 9
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
B Frage zu Unit-Tests Allgemeine Java-Themen 6
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
R Allgemeine Frage zu RMI bei MVC Allgemeine Java-Themen 2
O Frage zum Runtimeverhalten von Java ... Allgemeine Java-Themen 2
H Rundreise frage (Algorithmus) Allgemeine Java-Themen 18
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
D Frage zu Vererbung Allgemeine Java-Themen 5
J Frage zu regulärem Ausdruck Allgemeine Java-Themen 2
M Allgemeine Frage: Wie lernt man Java / Programmieren von Grund auf? Allgemeine Java-Themen 7
rentasad Design-Frage - Interfaces, Klassen, statische Methoden Allgemeine Java-Themen 3
S Frage zur JLS Allgemeine Java-Themen 0
J Verständnis Frage zur Instanz, Objekte, Instanzierung, Referenz Allgemeine Java-Themen 14
A Methoden Allgemeine Java Frage Allgemeine Java-Themen 3
E String Frage Allgemeine Java-Themen 9
I bin neu bei GitHub, Frage zur Sicherheit Allgemeine Java-Themen 14
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
C KeyListener Frage Allgemeine Java-Themen 3
T Frage zu UML in Java programmieren Allgemeine Java-Themen 1
R Konstanten initialisieren - FRAGE Allgemeine Java-Themen 3
MTJ004 FTP Frage zu FTP Speicherung Java-Android-FTP Allgemeine Java-Themen 5
J Frage zum Entwurf / json-Datenmodell Allgemeine Java-Themen 8
A Frage zu meinem Code Allgemeine Java-Themen 2
RalleYTN Classpath Nur ne kleine Frage zur MANIFEST.MF Allgemeine Java-Themen 4
T Frage zu Access Modifiers Allgemeine Java-Themen 6
W Input/Output Frage zu pdfbox und FileUtils Allgemeine Java-Themen 2
O Frage zur Implementierungsweise Allgemeine Java-Themen 4
B Frage zu Bitshift Allgemeine Java-Themen 3
J Java Zufallsgenerator (6 aus 49) Frage Allgemeine Java-Themen 7
L Frage zu RIA und GWT Allgemeine Java-Themen 0
P Concurrency Frage Allgemeine Java-Themen 8
M Frage zu Enumerations Allgemeine Java-Themen 2
F Unlimited Strength Policy. Frage Verbreitung der Anwendung Allgemeine Java-Themen 1
F Frage zur Library JTS Allgemeine Java-Themen 5
S Java Design Frage Allgemeine Java-Themen 10
E Reflection? Frage Allgemeine Java-Themen 4
C FileInputStream frage Allgemeine Java-Themen 6
G Polymorphie Programmdesign Frage Allgemeine Java-Themen 20
Uzi21 Frage zu NetBeans ( Console) Allgemeine Java-Themen 11
D Classpath Frage zum Java Resource Loading Allgemeine Java-Themen 2
G Frage zu JPA Allgemeine Java-Themen 1
S Methoden Frage Allgemeine Java-Themen 2
P MVC - Frage zu Model Allgemeine Java-Themen 4
K Frage zu Locks Allgemeine Java-Themen 1
S Frage zu abstract Allgemeine Java-Themen 5
M ArrayList<String> Frage Allgemeine Java-Themen 7
M OOP Design Frage Allgemeine Java-Themen 2
N Frage zur while-Schleife Allgemeine Java-Themen 18
T Best Practice Auslesen von Zeichenketten (Frage, Antworten, usw) Allgemeine Java-Themen 4
C Eine Frage zur Bearbeitungszeit Allgemeine Java-Themen 8
H Frage wegen Heap-Speicher Allgemeine Java-Themen 2
T Garbage Collection Frage Allgemeine Java-Themen 15
P Kurze Frage: aus einer File die Zeilenanzahl auslesen Allgemeine Java-Themen 9
D Frage zu Java und Umlauten / charsets Allgemeine Java-Themen 2
B Frage zu Java und OpenGL? Allgemeine Java-Themen 3
Q Kapselung Allgemeine Design- Frage Allgemeine Java-Themen 8
A eine test thread.join() frage Allgemeine Java-Themen 2
DStrohma LayoutManager Frage zum GridBagLayout Allgemeine Java-Themen 4
F Frage zu Regex möglich Allgemeine Java-Themen 4
H XML-File mit Java erzeugt Frage Allgemeine Java-Themen 10
D Frage und Antwort Programm, Problem bei Methodenaufruf Allgemeine Java-Themen 3
J NetBeans Frage bezüglich der Scanner-Klasse Allgemeine Java-Themen 6
H Java Vector Frage Allgemeine Java-Themen 9
W Frage... Allgemeine Java-Themen 29
R Frage zur topologischen Sortierung Allgemeine Java-Themen 2
H Frage zu weka.core.Instance Allgemeine Java-Themen 3
Y Kleine Frage zu String.split Allgemeine Java-Themen 3
T Frage zu Klassendesing Allgemeine Java-Themen 3
W Frage zu Refactoring statischer Methoden Allgemeine Java-Themen 4
C Eclipse Wichtige frage Allgemeine Java-Themen 5
H Frage zu java.weka.core.Instances Allgemeine Java-Themen 3
S Frage zu Format Modifiers in Log4j Allgemeine Java-Themen 11
H Frage zu clone() Allgemeine Java-Themen 5
4 Simple(?) Frage zu Threads Allgemeine Java-Themen 14
H2SO3- SCJP Chapter 3 Frage 10. Falsche Antwort? Allgemeine Java-Themen 15
H Frage sinnvolle Datenspeicherung und -verarbeitung Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben