Frage zu Memory Leak, Garbage Collection und Profiler-Tools

Status
Nicht offen für weitere Antworten.

-frank

Bekanntes Mitglied
ich habe das Problem dass der Speicherverbrauch meiner Applikationen in bestimmten Situationen rapide ansteigt (von wenigen MB zu ~70MB). der Speicher steigt nicht ins Unendliche an (sondern eben nur bis auf ~70MB), aber diese 70MB werden nie wieder freigegeben.
ich habe ein den Profiler JProbe verwendet um das Problem aufzuspüren. dort sehe ich, dass wie gesagt etwa 60/70 MB gebraucht werden (70 alloziert, 60MB wirklich genutzt). Diese werte ändern sich auch nach Minuten noch nicht. Klicke ich nun in JProbe auf "request Garbage Collection" sinkt der Speicherverbrauch auf 3/10 MB ab. Meine erste Frage nun: tut JProbe da irgendetwas besonders? wieso funktioniert es, wenn JProbe den "Befehl" zum Aufräumen gibt?

zweite frage: ich habe einige Forum-Threads zu dem Thema überflogen und bin auf System.gc() gestoßen. ALso hab ich meiner Applikation einen Button spendiert, der System.gc() aufruft. Und siehe da, auch das reduziert den Speicherverbrauch enorm! --> zweite frage ist ähnlich wie die erste: was macht System.gc(), was die normale Garbage Collection nicht macht? (Laut Dokumentation sagt es dem System doch nur, dass jetzt ein guter Zeitpunkt zum Aufräumen wäre.)

Dritte Frage: wenn System.gc() bzw. JProbe den Speicher aufräumen können, das ganze aber nicht automatisch passiert, deutet das dann eher auf einen Bug hin oder liegt der Fehler vermutlich trotzdem bei mir? Wenn er bei mir liegen sollte: kann mir jemand einen Beispiel-Code nennen, der den Speicherverbrauch so erhöht, dass er von der automatischen GC nicht mehr reduziert werden kann, sehr wohl aber von System.gc()? (mich verwirrt dies alles ein wenig, da ich mich um die GC in Java noch nie gekümmert habe...)
 
M

maki

Gast
Wohl eher 64MB bzw. knapp darunter, 64MB ist der Standard Speicher für die VM.

Der GC rennt erst los, wenn diese 64MB fast voll sind, nicht vorher.
Mit System.gc() kann man dem System vorschlagen, den GC aufzurufen.

Wenn nach dem GC der Speicher wieder frei ist, ist es kein echtes Memoryleak, sondern eher ein Hinweis darauf, dass deine Anwendung eben diesen Bedarf hat.

Vielleicht kann man den Speicher"verbrauch" noch optimieren, aber dazu müsste man schon Details kennen.
 

-frank

Bekanntes Mitglied
hmm, korrekt, im Profiler sinds exakt 64MB.

okay, verstehe ich das richtig?:
es gibt vereinfacht gesagt Garbage Collection auf verschiedenen Leveln. Manche, für die GC "offensichtliche" Objekte/Referenzen werden auch unter 64MB gelöscht. Beispiel: eine schleife, die 500000000 strings erzeugt verbraucht bei mir laut Profiler nie mehr als 1MB.
Andere ebenfalls löschbare Objekte werden schwerer erkannt, wodurch das Aufspüren mehr Performance kostet. Deswegen wird diese "volle" Garbage Collection (per Default) erst bei 64MB ausgelöst oder eben durch System.gc().

Wenn mein Programm (fast) auf die 64MB kommt, aber durch System.gc() locker wieder auf 5MB runter geht, bedeutet das, dass ich solche "schwer aufzuspürenden" Objekte habe. Es ist aber weder ein Java-Bug noch ein Bug in meinem Programm. korrekt?

und die "volle" GC wird automatisch unter 64MB nie ausgeführt und über 64MB auch nur soweit, dass das Programm wieder weniger als 64MB braucht (was erklärt, warum der Speicherverbrauch nie wieder reduziert wird).

oder hab ich das jetzt komplett falsch verstanden? ;)
 
M

maki

Gast
Manche, für die GC "offensichtliche" Objekte/Referenzen werden auch unter 64MB gelöscht.
Nein, normalerweise läuft der GC nie an, bis eben der Speicher fast voll ist, oder du mit System.gc() sugerrierst das er starten sollte.

Andere ebenfalls löschbare Objekte werden schwerer erkannt, wodurch das Aufspüren mehr Performance kostet. Deswegen wird diese "volle" Garbage Collection (per Default) erst bei 64MB ausgelöst oder eben durch System.gc().
Wenn der GC läuft, steht alles andere im System!
Deswegen läuft er auch nur wenn es sein muss ;)

Es gibt imho keine "schwer" oder "leicht" erkennbaren "löschbare Objekte", entweder ein Objekt kann recycled werden, oder eben nicht.

Beispiel: eine schleife, die 500000000 strings erzeugt verbraucht bei mir laut Profiler nie mehr als 1MB.
Schlechtes Beispiel, da der Kompilier speziell String sehr gut optimieren kann.
Vergleiche doch mal deinen Originalcode mit dem dekompilierten code aus zB. Frontend Plus, du wirst überrascht sein da eine andere Klasse zu finden (zB. StringBuilder) ;)
Auch kann die Hotspot VM zur Laufzeit deinen Code optimieren, ist alles keine exakte Wissenschaft..
 

-frank

Bekanntes Mitglied
hab das aus diesem absatz:

A third category where developers often mistakenly think they are helping the garbage collector is the use of System.gc(), which triggers a garbage collection (actually, it merely suggests that this might be a good time for a garbage collection). Unfortunately, System.gc() triggers a full collection, which includes tracing all live objects in the heap and sweeping and compacting the old generation. This can be a lot of work. In general, it is better to let the system decide when it needs to collect the heap, and whether or not to do a full collection. Most of the time, a minor collection will do the job.

quelle: http://www.ibm.com/developerworks/java/library/j-jtp01274.html

wurde hier gepostet im forum.

der speicherverbrauch meiner applikation ändert sich laut Profiler alle paar sekunden (und geht auch manchmal nach unten). also IMO wird die GC da schon automatisch gestartet. wenn nicht, müsste ja eine simple applikation die nur ein popup-menu anzeigt auf 64MB kommen, wenn man oft genug das menu anzeigen und wieder verschwinden lässt.
 

-frank

Bekanntes Mitglied
maki hat gesagt.:
Das mit der "minor collection" wusste ich nicht, danke.

auch ich nicht bis vor ner stunde ;)

aber danke auch an dich. das mit den 64MB hat mir sehr geholfen, da ich jetzt weiß, dass ich keinen bug bzw. kein memory leak habe, sondern einfach nur Objekte, die nicht "so leicht" zu entfernen sind.

falls es wen interessiert: das problem entsteht im zusammenhang mit Font.deriveFont(float). wenn man viele Font objekte von einander ableitet, bleiben anscheinend alle bestehen (bzw. zumindest manche referenzen/objekte). nur die "volle" garbage collection findet diese objekte dann. dafür ist deriveFont anscheinend auch schneller als new Font(..) (wobei ich das jetzt nur in einer schleife kurz getestet habe).
 
Status
Nicht offen für weitere Antworten.
Ä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