Swing Wird invisible, nicht-ref. Fenster vom GC entfernt?

jakob190590

Aktives Mitglied
Hallo,

ich bin mir grade unsicher, ob ich das machen darf:
Ein Fenster (JInternalFrame) nicht dispose() 'en, auch wenn ich es nicht mehr brauche.

Oder anders gesagt:
Wird ein nicht-referenziertes und unsichtbares Fenster vom Garbage-Collector entfernt, auch wenn nicht dispose() aufgerufen wurde? (Sollte es ja, weil es dann unbrauchbar ist für mich.)


Ich hoffe ihr versteht mein Problem, ich hab eben Angst, dass mich in dem Fall der GC im Stich lässt.
Danke schon mal für die Antworten!
 
G

Gast2

Gast
Hm ich bezweifel dass du alle Referenzen auf den Frame loswirst wenn du einfach nur mit setVisible(false); arbeitest.
dispose() räumt intern noch ein wenig auf.
 

FArt

Top Contributor
Ich hoffe ihr versteht mein Problem, ich hab eben Angst, dass mich in dem Fall der GC im Stich lässt.
Danke schon mal für die Antworten!

Keine Angst!

Das kannst du ohne viel Aufwend selber herausfinden: Mache einen Heap-Dump deiner laufenden Applikation, suche dir das unsichtbare Objekt und schaue wer es wie referenziert.

Bei einer harten Referenz wird der GC es nicht löschen, sonst kann es bei Bedarf gelöscht werden.

Die Antwort lässt sich übrigens auch nur über Sourcecode lesen (steht ja alles zur Verfügung) finden!

Stell doch mal eine begründete Behauptung auf, dann lässt es sich viel besser diskutieren.
 

jakob190590

Aktives Mitglied
Ok, danke FArt:
Selber rausfinden mit Heap-Dump, da hab ich keine Ahnung wie das geht, das einzige was mir dazu eingefallen wäre ist im TaskManager den Speicherbedarf des Progs zu überwachen...

Wo ich im SourceCode schauen muss weiß ich ehrlich gesagt auch nicht. Bei dispose() nicht, weil das ruf ich ja nicht auf, wo sonst? System.gc()?

Meine Befürchtung, dass der GC da nicht waltet, rührt eben daher, dass in der API zu dispose() steht, dass die Methode die Ressourcen freigibt. Warum gibt es die Methode, wenn es (hoffentlich) sowieso der GC macht? Weiter begründen kann ich das nicht ^^

Ich hab eigentlich nur folgenden Aufruf...
Java:
// methoden-anfang
MyInternalFrame mif = new MyInternalFrame();
mif.setDefaultCloseOperation(JInternalFrame.HIDE_ON_CLOSE); // wird eben nicht dispose() 'd
mif.setVisible(true);
// methoden-ende

aber je länger ich drüber nachdenke, desto mehr glaube ich auch, dass der GC des entfernt, wenn das Frame wieder vom User unsichtbar gemacht wird.

Danke jedenfalls nochmal!
 
Zuletzt bearbeitet:
G

Gastredner

Gast
Meine Befürchtung, dass der GC da nicht waltet, rührt eben daher, dass in der API zu dispose() steht, dass die Methode die Ressourcen freigibt. Warum gibt es die Methode, wenn es (hoffentlich) sowieso der GC macht? Weiter begründen kann ich das nicht ^^
Vermutlich, weil es sich um native Resourcen handelt:
Java API hat gesagt.:
void java.awt.Window.dispose()

Releases all of the native screen resources used by this Window, its subcomponents, and all of its owned children. That is, the resources for these Components will be destroyed, any memory they consume will be returned to the OS, and they will be marked as undisplayable.
Ich kann mir eigentlich auch nicht vorstellen, dass der GC ein nicht freigegebenes Window entfernt - in diesem Falle blieben die nativen Resourcen ja weiterhin reserviert, was eigentlich nicht sein sollte. Ich fände es schwer zu glauben, dass die Entwickler solch ein Problem übersehen haben sollten.
 

darkeye2

Bekanntes Mitglied
Was spricht eigentlich dagegen das frame mit dispose zu löschen? bzw mit EXIT_ON_CLOSE ? Wenn man den sinn sehen würde es nicht zu benutzen ist es wahrscheinlich auch einfacher dein problem nach zu vollziehen.
 

jakob190590

Aktives Mitglied
Ich kann mir eigentlich auch nicht vorstellen, dass der GC ein nicht freigegebenes Window entfernt - in diesem Falle blieben die nativen Resourcen ja weiterhin reserviert, was eigentlich nicht sein sollte. Ich fände es schwer zu glauben, dass die Entwickler solch ein Problem übersehen haben sollten.
Aber die Entwickler dürften doch auch nicht übersehen, dass ein Fenster für immer im RAM bleibt, wenn ich nicht dispose() aufrufe. Das darf doch auch nicht sein...

Was spricht eigentlich dagegen das frame mit dispose zu löschen? bzw mit EXIT_ON_CLOSE ?
Der Grund ist folgender: Das Frame stellt eine Suchfunktion bereit und kann als "StandAlone-InternalFrame" verwendet werden, aber auch per API von anderen Programmteilen.
Wenn es von anderen Programmteilen verwendet wird, darf nicht DISPOSE_ON_CLOSE eingestellt sein, weil es vllt noch gebraucht wird! Man könnte natürlich die DefaultCloseOperation ändern, aber das ist in dem Fall umständlich und fehleranfällig.

Ich will einfach nur wissen, ob man dispose() aufrufen muss, wenn man ein Frame nicht mehr braucht.
 
Zuletzt bearbeitet:

Atze

Top Contributor
ich versteh den gedanken in deinem fall mal garnicht. vielleicht bin ich grad auch zu unnüchtern :D , aber das ist eine desktopanwendung, oder? wo ein üser dran arbeitet? oder eine methode auf dem server? multiuser?
wenn es ne desktopanwendung ist, warum greift dann die api irgendwie auf die gui der suche zu, wenn der user das fenster geschlossen hat? und wenn es eine serveranwendung ist, teilen sich da mehrere user ein suchfenster? :) ich grübel die ganze zeit, aber ich komm nich drauf, wie das szenario da ist! :) sorry wenn ich einfach zu blöd bin! :)
 

jakob190590

Aktives Mitglied
Und wo ist das Problem? Bereits freigegebene Fenster können laut Javadoc ja jederzeit wieder genutzt werden.
Aber es kann doch nicht die gleiche Instanz wieder angezeigt werden! dispose() und dann setVisible(true) zeigt mir eindeutig kein Fenster an.

, aber das ist eine desktopanwendung, oder? wo ein üser dran arbeitet? oder eine methode auf dem server? multiuser?
wenn es ne desktopanwendung ist, warum greift dann die api irgendwie auf die gui der suche zu, wenn der user das fenster...
Es ist eine Desktopanwendung, hat nichts mit Server zu tun. Die API (also Methoden, Attribute) die mein InternalFrame bereitstellt, ist für andere Programmteile (z.B. Frames) der GLEICHEN Anwendung! (Das nennt man doch auch API?)
 

Atze

Top Contributor
also unter api verstehe ich meist den core des projekts, ja, wo wie du sagst, die methoden und attribute von der gui (den frames) benutzt werden. und dein suchframe stellt sie wie bereit? dann haben die anderen frames doch sicher referenzen auf darauf, oder? es sein denn, diese anderen frames wären auch zerstört. also hast du immer eine referenz, solange du sie brauchst, auch wenn du das fenster nicht mehr siehst. ich finds aber immernoch komisch, dass ein fenster schnittstellen bietet! :)
 

jakob190590

Aktives Mitglied
also unter api verstehe ich meist den core des projekts, ja, wo wie du sagst, die methoden und attribute von der gui (den frames) benutzt werden. und dein suchframe stellt sie wie bereit? dann haben die anderen frames doch sicher referenzen auf darauf, oder? es sein denn, diese anderen frames wären auch zerstört. also hast du immer eine referenz, solange du sie brauchst, auch wenn du das fenster nicht mehr siehst. ich finds aber immernoch komisch, dass ein fenster schnittstellen bietet! :)
es ist nicht komisch, dass eine suchfunktion (samt fenster) von einem anderen Programmteil genutzt wird und daher schnittstellen bieten muss. ich will das gar nicht diskutieren, du kennst ja mein projekt nicht.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
N Lwjgl 3d Objekt wird schmaler, wenn es sich dreht Allgemeine Java-Themen 0
D Linux, Java-Version wird nicht erkannt bzw. welche Einstellung fehlt noch? Allgemeine Java-Themen 19
berserkerdq2 Wenn ich einfach eine GIF in den Scenebuilder als Bild reinpacke, wird das dann asl Gif angezeigt Allgemeine Java-Themen 1
G Popup wird nicht sichtbar Allgemeine Java-Themen 9
8u3631984 Funktions Parameter mit Lombok "NonNull" annotieren wird in Jacococ Testcoverage nicht herausgefiltert Allgemeine Java-Themen 3
M Java Überprüfen ob .exe-Datei bereits ausgeführt wird Allgemeine Java-Themen 2
Calli11 Was muss ich hier in die Main schreiben, damit das Programm ausgeführt wird? Allgemeine Java-Themen 4
Sachinbhatt Wie wird die Typumwandlung bei Mehrfachvererbung in Java implementiert? Allgemeine Java-Themen 3
Y MVVM wie wird Eventhandler tausch geregelt Allgemeine Java-Themen 4
berserkerdq2 run-methode eines Threads so programmieren, dass 30x die Sekunde etwas ausgeführt wird. Allgemeine Java-Themen 44
T ImageIcon wird nicht angezeigt Allgemeine Java-Themen 6
N Warum wird die For Schleife nicht betreten Allgemeine Java-Themen 4
N warum wird es doppelt ausgegeben Allgemeine Java-Themen 6
A code wird nicht ausgeführt Allgemeine Java-Themen 3
Y Warum wird das JLabel falsch verschoben? Allgemeine Java-Themen 1
T Schaltfläche wird nicht gefunden Allgemeine Java-Themen 4
N Eingabe wird immer als "false" ausgegeben Allgemeine Java-Themen 6
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
M Frage-Antwortspiel wie Wer wird Millionär Allgemeine Java-Themen 1
Zrebna Gibt es eine Möglichkeit eine NPE zu vermeiden, wenn null returned wird? Allgemeine Java-Themen 3
R Warum wird mir in der Konsole das "Standard Array" ausgegeben? Allgemeine Java-Themen 2
C FileLock - Exception wird immer geworfen Allgemeine Java-Themen 4
R Was muss ich ändern, damit der Kreis links unten gezeichnet wird? Allgemeine Java-Themen 17
hello_autumn Java_Home geändert auf Java 13, trotzdem wird Java Version 8 angezeigt. Allgemeine Java-Themen 2
Thallius Char +1 wird int? Allgemeine Java-Themen 7
S Wenn eine Klasse zwei Interfaces mit derselben Methodensignatur implementiert: welche wird aufgerufen? Allgemeine Java-Themen 15
F Scrollbar wird nicht angezeigt Allgemeine Java-Themen 0
B Discord Bot - Funktion wird nicht aufgerufen Allgemeine Java-Themen 1
I Temp-Datei wird nicht gelöscht Allgemeine Java-Themen 12
S If-Menü wird doppelt ausgegben Allgemeine Java-Themen 4
P Variable wird in for - loop nicht richtig hochgezählt Allgemeine Java-Themen 11
S Wird bei den JREs 9, 10, 11+ ueberhaupt noch Bytecode ausgefuehrt..? Allgemeine Java-Themen 8
FRI3ND JFrame wird nicht angezeigt Allgemeine Java-Themen 3
T Plötzlich wird package nicht mehr gefunden Allgemeine Java-Themen 3
X Klassen File-Klasse wird als Directory markiert Allgemeine Java-Themen 8
S Datei wird nicht gefunden Thread.currentThread().getContextClassLoader().getResourceAsStream() Allgemeine Java-Themen 1
mrbig2017 Sleep wird ignoriert und der Thread wartet nicht Allgemeine Java-Themen 1
mrbig2017 Threads wait wird nicht durch notify beendet! Allgemeine Java-Themen 3
kodela Klassen Klassenvariable wird nicht gesetzt Allgemeine Java-Themen 23
M Was geschieht mit Java-Klasse, die aus ArrayList entfernt wird? Allgemeine Java-Themen 10
kodela Drücken der ALT-Taste wird nur bei jedem zweiten Mal erkannt Allgemeine Java-Themen 5
Arif Input/Output Serialisierung - Datei wird nicht erzeugt Allgemeine Java-Themen 3
D Cursor unsichtbar, wenn Kontextmenü aufgerufen wird Allgemeine Java-Themen 5
K Arbeitsspeicher wird langsam voll Allgemeine Java-Themen 6
The Pi Wie oft wird ein Buchstabe in einem Wort wiederholt? Allgemeine Java-Themen 16
N Datentypen If-Statement wird "übersprungen" Allgemeine Java-Themen 2
F Java Mail Problem: Authentifizierung wird nicht immer mitgeschickt Allgemeine Java-Themen 1
T Textarea text wird immer überschrieben Allgemeine Java-Themen 4
C Durch klicken von Button in GUI wird leeres Fenster geöffnet und nicht mein Spiel "Memory" Allgemeine Java-Themen 13
T Java wird nicht gefunden Allgemeine Java-Themen 32
Tacofan GIF-Bild wird "zerstört" Allgemeine Java-Themen 3
Z Exception wird nicht ausgelöst Allgemeine Java-Themen 2
Sin137 Interface Eingabe wird doppelt angezeigt Allgemeine Java-Themen 2
B Threads Timer wird immer schneller Allgemeine Java-Themen 6
N Maven ObjectMapper Error wenn das File gespeichert wird Allgemeine Java-Themen 0
G Methoden Aus einem Event, wo ich weiß, dass es ausgeführt werden wird, eine Get-Methode basteln Allgemeine Java-Themen 8
F Wert in Variable schreiben, wenn diese gerade genutzt wird Allgemeine Java-Themen 10
E Java wird beendet nach paar Sekunden Allgemeine Java-Themen 14
U Erkennen, ob PC benutzt wird Allgemeine Java-Themen 4
O Programm wird einfach "gekillt" Allgemeine Java-Themen 3
P Prüfen ob es Variable mit Namen gibt der als String übergeben wird Allgemeine Java-Themen 7
P Zwei ArrayLists: Ohne die eine überhaupt anzurühren, wird sie verändert Allgemeine Java-Themen 2
B Abfragenteil wird nicht aufgerufen Allgemeine Java-Themen 2
Todesbote JFileChooser im Vordergrund (*.jar wird mittels shell_exec in PHP aufgerufen) Allgemeine Java-Themen 1
T Sicherheitshinweis - Zertifikat wird angefordert Allgemeine Java-Themen 5
L SetBounds wird vor dem Konstruktorcode aufgerufen - Wenn Startleiste links Allgemeine Java-Themen 1
P "Overriden statische Methode" Statische Methode die vererbt wird Allgemeine Java-Themen 5
I CountDown wird durch JOptionPane unterbrochen Allgemeine Java-Themen 11
P Wird double und float auf jedem Computer gleich berechnet? Allgemeine Java-Themen 10
G Tabelle wird nicht richtig dargestellt Allgemeine Java-Themen 9
HarleyDavidson Threads ProgressMonitor wird nicht angezeigt! Allgemeine Java-Themen 6
J OOP Überwachen, ob ein Objekt erzeugt wird Allgemeine Java-Themen 9
S Byte Array welches in Laufzeit aufgelöst wird // Objekt Array Allgemeine Java-Themen 3
A Long variable wird negativ??? Allgemeine Java-Themen 1
J CSV Datei wird ungewollt umformatiert Allgemeine Java-Themen 5
T MEthodenauruf testen, wenn instanz erst erzeugt wird Allgemeine Java-Themen 0
gamebreiti Swing JLabel wird nicht angezeigt Allgemeine Java-Themen 4
I Java Applet wird immer blockiert Allgemeine Java-Themen 3
E Java Editor Klasse wird nicht weiter ausgeführt Allgemeine Java-Themen 4
S Java Applet wird dauerhaft blockiert Allgemeine Java-Themen 1
I Datei wird nicht richtig gelöscht Allgemeine Java-Themen 7
K Methoden Objekt wird nicht erkannt Allgemeine Java-Themen 11
D Input/Output Datei wird lokal aber nicht vom Webserver ausgelesen... Allgemeine Java-Themen 2
F Nach Export wird PDF Datei nicht mehr gefunden Allgemeine Java-Themen 0
L Prüfen, ob Programm über 32bit oder 64bit Java ausgeführt wird Allgemeine Java-Themen 4
D ActionListener wird mit jedem Mal öfter aufgerufen Allgemeine Java-Themen 2
C System.in erhält Input von Tastatur. wo wird das festgelegt? Allgemeine Java-Themen 4
I Projekt wird nicht erstellt Allgemeine Java-Themen 2
T WeakReference/PhantomReference: Mitbekommen WELCHES Objekt nun GC'ed wird Allgemeine Java-Themen 2
A Threads Log4J Logger wird "überschrieben" Allgemeine Java-Themen 3
P Check, welche Java Version installiert bevor ein Programm ausgeführt wird. Allgemeine Java-Themen 12
J batch datei wird nicht aufgerufen Allgemeine Java-Themen 11
M Datei wird nicht vollständig geschrieben (FileOutputStream, OutputStreamWriter, Encoding) Allgemeine Java-Themen 6
P OSGi - Bundle-Methode wird nicht aufgerufen Allgemeine Java-Themen 3
S Antlr Grammatik übersetzt ohne Fehler, dennoch wird Zahl nicht als Eingabe erkannt Allgemeine Java-Themen 4
T Variablen Variable wird als nicht genutzt angezeigt Allgemeine Java-Themen 8
J Slideshow wird im IE überblendet Allgemeine Java-Themen 4
O Socket Object wird scheinbar falsch empfangen Allgemeine Java-Themen 6
J Textdatei auslesen, die gerade benutzt wird Allgemeine Java-Themen 8
M CapsLock abfragen wenn Fenster wieder aktiviert wird Allgemeine Java-Themen 5

Ähnliche Java Themen

Neue Themen


Oben