Frage zu ThreadLocal

Generic1

Top Contributor
Hallo,

ich hatt folgendes Problem in der Klasse unten, also eine Klasse welche Singleton ist, es müsste also nur ein Objekt dieser Klasse geben, Meine Applikation läuft in einem JBoss- context.

Wenn ich jetzt das Programm ausgeführt habe, dann würde mit der Methode setCurrentUser ein user gesetzt. Im weiteren Programmablauf würde die Methode getCurrentUser aufgerufen und diese Methode gab dann "null" zurück -> und das kann ich mir jetzt nicht erklären, es gibt ja nur ein Objekt von der Klasse MyClass und daher auch nur einen ThreadLocal "user".
Warum dann null zurückgegeben wird obwohl vorher schon ein User mit setCurrentUser gesetzt wurde ist mir absolut nicht klar.
Mein workaround war jetzt, dass ich den ThreadLocal "static" mache, dann gehts natürlich und es deutet für mich auch darauf hin, dass es mehrere Instanzen der Klasse MyClass gibt, wie das aber sein kann bei einer Singleton- Klasse ist mir nicht klar.

Hat vielleicth jemand eine Idee, warum das sein kann,
Vielen Dank,
lg

Java:
pulic class MyClass extends BaseClass implements MyInterface {
    public final static MyClass INSTANCE = new MyClass();
  
    protected ThreadLocal<IUser> user = new ThreadLocal<IUser>()

    private MyClass() {}

    public void setCurrentUser(IUser user) {
      if(user != null )
        this.user.set(user)
       }

    public IUser getCurrentUser() {
       return this.user.get();
       }

   }
 

FArt

Top Contributor
Wie hast du sichergestellt, dass es nur eine Instanz von dieser Klasse geben kann?
Singleton (static) bedeutet nicht eine Instanz in einer VM, sondern für jeden Classloader, der die Klasse laden kann. Gerade in einem Applicationserver, der Classloader selber verwaltet (und auch noch konfigurierbar) sollte man auf solche Konstrukte verzichten, denn sie funktionieren nicht wie ein Java Programmier das erwartet.
Warum funktioniert es nicht wie du glaubst? Sei nicht so hilflos und hilf dir selber mal. Baue Logging in deinen Code ein ... Instanziierung der Klasse und setzen und holen von Userns. Hilfreich ist dabei, wenn du die Instanz identifizieren kannst (falls es mehrere gibt) und den aktuell gültigen Kontextclassloader und den aktuellen Thread.
 

Generic1

Top Contributor
Also, ich hab mich jetzt mal nicht so angestellt :) und hab in den Konstruktor ein System.out.println("...") reingegeben -> dieser Konstruktor von MyClass wird nur einmal aufgerufen, Trotdem bekomme ich bei einem Aufruf von getCurrentUser "null" zurück,
Also ganz versteh ich das jetzt nicht, vielleicht hat jemand noch eine Idee, was es da haben kann.
lg
 

FArt

Top Contributor
Dann ist vielleicht der setztende Thread nicht der holende Thread... siehe mein Anmerkung zu Logging oben.
Außerdem: dein Konstrukt kann in einer Enterprise-Umgebung grundsätzlich in die Hose gehen, abhängig von dem Kontext in dem es verwendet wird.

Was soll denn eigentlich wann (in welchem Kontext) erreicht werden?
 

tuttle64

Bekanntes Mitglied
Ein typisches Pattern für ein Singleton ist es, die MemberVariable des Typs Referenz als static zu deklarieren und innerhalb des Konstruktors zu prüfen, ob diese Variable null ist, denn nur dann wird eine Instanz erzeugt. Das könnte in etwa so aussehen (ohne extends BaseClass implements MyInterface):


Code:
public class MyClass {
	// static bedeutet user ist ein Klassenobjekt
	private static ThreadLocal<IUser> user = null;

	public MyClass() {
		if (user == null) {
			user = new ThreadLocal<IUser>();
			System.out.println("Neuer User erzeugt.");
		} else {
			System.out.println("Neuer User konnte nicht erzeugt werden.");
		}
	}

	public IUser getCurrentUser() {
		if (user != null) {
			return this.user.get();
		} else
			return null;
	}

	public static void main(String[] args) {
		MyClass c1 = new MyClass();
		MyClass c2 = new MyClass();
	}
}
 
S

SlaterB

Gast
@tuttle64
das scheint mir nicht gerade ein gängiges Beispiel, die statische Variable kannst du direkt initialisieren,
ansonsten passiert das beim ersten MyClass-Objekt, danach nie wieder,

ein User wird dabei noch nicht angelegt, kann auch gar nicht ohne eigene ThreadLocal-Klasse mit initialValue(),
eine Thread-Unterscheidung findet nicht wirklich statt
 

FArt

Top Contributor
Nichts. Ähm. Mittagspause...? :bahnhof: Passte nur zu deinem Hinweis ;)

Hoppla, ich habe nicht gesehen dass du gar nicht der TS warst... und habe den Zusammenhang deswegen nicht erkannt, denn Generic1 hatte ja schon gesagt es wäre definitiv nur eine Instanz.

Ein typisches Pattern für ein Singleton ist es, die MemberVariable des Typs Referenz als static zu deklarieren und innerhalb des Konstruktors zu prüfen, ob diese Variable null ist, denn nur dann wird eine Instanz erzeugt.
Ok, aber das ist ja auch nur eine Spielart des "normalen" Singleton und weist in einer Enterpriseumgebung (oder anderen Umgebungen, die Classloader managen) die selben Schwächen auf.
 
Ä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