Temp-Datei wird nicht gelöscht

inflamer

Bekanntes Mitglied
Hallo Forum,

gibt es hierfür eine elegante Lösung? Ich lege beim Programmstart eine temporäre Datei an, welche via RandomAccessFile permanent geöffnet bleibt, um bestimmte Lese- und Schreiboperationen vorzunehmen.

Wie eigentlich schon zu erwarten war, wird die Datei trotz .deleteOnExit() nicht gelöscht, weil die Datei zum Zeitpunkt des Schließens wohl noch geöffnet ist.

protected void finalize() {
myRandomAccessFile.close();
}


... bringt's schon mal leider nicht...
 

inflamer

Bekanntes Mitglied
Vielleicht sollte ich noch dazu sagen, dass sich das Ganze in einer abgekapselten Bibliothek abspielt, das eigentliche Programm "weiß" also sozusagen nichts von der temporären Datei. Die Bibliothek sollte sich also eigenständig drum kümmern. Ein manueller wie auch immer gearteter Aufruf von .close() aus dem Programm heraus gebietet sich also eher nicht so... ;-)
 

inflamer

Bekanntes Mitglied
"Was machst du denn bitte genau?"

In der Datei werden Undo/Redo-Aktionen gespeichert, die zu "speicherintensiv" sind, als dass man sie im RAM ablegen könnte/sollte.

Ja, war eben auch mein Verdacht, dass finalize() nicht aufgerufen wird. Ist im Prinzip auch logisch, denn wozu die ganzen Finalisierer aufrufen, wenn die VM gerade dabei ist sich komplett zu beenden.
 
K

kneitzel

Gast
Vielleicht sollte ich noch dazu sagen, dass sich das Ganze in einer abgekapselten Bibliothek abspielt, das eigentliche Programm "weiß" also sozusagen nichts von der temporären Datei. Die Bibliothek sollte sich also eigenständig drum kümmern. Ein manueller wie auch immer gearteter Aufruf von .close() aus dem Programm heraus gebietet sich also eher nicht so... ;-)
Also meiner Meinung nach sollten dann Instanzen, die sowas haben, eben auch Closeable / AutoCloseable implementieren, damit die Verwender mitbekommen, dass da eine Ressource geöffnet wird, die geschlossen werden muss wenn man fertig ist.

Und dann ist das eine einfache Close Methode, die das Schließen des temporären Files halt mit veranlasst.
 

inflamer

Bekanntes Mitglied
Danke für Deine Antwort! AutoClosable gibt's leider erst ab Java 7, ich arbeite noch mit 6. Daher fällt diese Variante leider schon mal weg.

Letztendlich wird's wohl darauf hinauslaufen (müssen), dass ich die Datei bei Zugriff immer wieder neu öffne und anschließend wieder schließe. Nicht 100%ig befriedigend, aber besser so, als die Datei gar nicht zu löschen und damit auf Dauer unnötig den Festplattenplatz vollzumüllen.
 
K

kneitzel

Gast
Danke für Deine Antwort! AutoClosable gibt's leider erst ab Java 7, ich arbeite noch mit 6. Daher fällt diese Variante leider schon mal weg.

Aber Closeable sollte es doch auch schon vorher gegeben haben? Ist schon so lange her, dass ich mich nicht erinnere....
Ansonsten einfach ohne Interface ein close() anbieten und in der Doku entsprechend beschreibe...

Letztendlich wird's wohl darauf hinauslaufen (müssen), dass ich die Datei bei Zugriff immer wieder neu öffne und anschließend wieder schließe. Nicht 100%ig befriedigend, aber besser so, als die Datei gar nicht zu löschen und damit auf Dauer unnötig den Festplattenplatz vollzumüllen.
Da bin ich jetzt nicht sicher, ob und wie das Dein Problem löst (Was aber natürlich auch nicht wichtig ist. Wenn Du eine Lösung hast, mit der Du arbeiten kannst, dann ist es super. Mir muss das auch nicht erläutert werden, aber ich bin halt ein neugieriger Mensch :) ): Geschlossen wird die Datei ja. So Inhalte fehlen, dann wäre ein regelmäßiges flushen evtl. zielführend. So wie ich dich verstanden hatte, ist ja das Problem, dass die Datei beim Schließen der Applikation nicht gelöscht wird.

Oder meinst Du damit, dass z.B. mit Speichern der Datei der undo Speicher gelöscht wird, d.h. beim Speichern wird die Datei geschlossen und damit gelöscht? (Das würde dann natürlich funktionieren und wäre eine Lösung für das Problem aber halt auf Kosten der Undo-Funktionalität).

Eine andere Idee könnte evtl. sein, dass die Datei(en) geöffnet bleiben und bei Programmstart ein "cleanup" durchgeführt wird. (Das wäre das, was man z.B. von Tools wie notepad++ kennt. Ich liebe es für Notizen auf Arbeit: Einfach neues Tab und reinschreiben. Wird nie gespeichert und ist bei jedem Neustart halt direkt wieder da... Sprich: So ein cleanup kann ja beliebig definiert werden: Verwendung der Dateien soweit möglich oder einfaches löschen von alten, nicht mehr verwendeten Dateien..)

Das wären einfach nur meine Gedanken dazu. Keine Ahnung, ob sie hilfreich für Dich sind, denn ich bin mir sicher, dass du das Alles und noch mehr bestimmt schon in der Tiefe alles durchdacht hast.
 

inflamer

Bekanntes Mitglied
>> Da bin ich jetzt nicht sicher, ob und wie das Dein Problem löst

Na ja, weil nach jedem Zugriff auf die Datei jedes Mal ein Aufruf von RandomAccessFile#close() folgt, ist die Datei eben nicht mehr geöffnet, wenn das Programm vom Anwender geschlossen wird, folglich wird die Datei von der VM gemäß .deleteOnClose() "ordnungsgemäß" gelöscht. Das wäre eben dann die Lösung.

>> Eine andere Idee könnte evtl. sein, dass die Datei(en) geöffnet bleiben und bei Programmstart ein "cleanup" durchgeführt wird.

Das ist übrigens auf jeden Fall eine gute Variante, komisch, dass ich nicht von selbst drauf gekommen bin. Danke!

Damit habe ich schon mal 2 Alternativen. Damit kann ich arbeiten. ;-)
 
K

kneitzel

Gast
>> Da bin ich jetzt nicht sicher, ob und wie das Dein Problem löst

Na ja, weil nach jedem Zugriff auf die Datei jedes Mal ein Aufruf von RandomAccessFile#close() folgt, ist die Datei eben nicht mehr geöffnet, wenn das Programm vom Anwender geschlossen wird, folglich wird die Datei von der VM gemäß .deleteOnClose() "ordnungsgemäß" gelöscht. Das wäre eben dann die Lösung.
Mein Verständnis ist, dass bei der StandardOpenOption.DELETE_ON_CLOSE die Detei beim schließen der Datei gelöscht wird und nicht beim schließen der VM.
Somit wäre die Datei nach deinem RandomAccessFile#close() Aufruf nicht nur nicht mehr geöffnet sondern auch direkt gelöscht.

Aber ich möchte nicht ausschließen, dass ich irgendwas missverstanden habe und Du ein anderes deleteOnClose verwendest als das, was ich gerade vor Augen habe (Zumal ich bei allen Recherchen zu Lösungen immer Java 7+ sehe - also da kann es dann auch noch Unterschiede geben!). Zur Not gilt: Einfach einmal testen und schauen ob es funktioniert. Hier würde ich mich für Dich freuen, wenn ich einfach falsch liegen würde. :)
 

mrBrown

Super-Moderator
Mitarbeiter
Ich würde auch versuchen, das Interface des ganzen um Closeable zu erweitern, wäre mMn die sauberste Lösung.

Ansonsten könnte man uU mit Shutdown-Hooks arbeiten, und dort den Stream schließen und die Datei selbst löschen.

Kann natürlich trotzdem beim Start noch vorhanden sein, sollte also dort in jedem Fall geleert werden. Eine Möglichkeit wären da aber temporäre Dateien, dann hat man jeden Start ne neue (oder wenn mehrere Instanzen laufen)
 

inflamer

Bekanntes Mitglied
Runtime.getRuntime().addShutdownHook(new Thread() { public void run() {
try { if (randomAccessFile != null) randomAccessFile.close(); } catch (Exception e) {}
}});


<-- funktioniert anstandslos. Danke für den Tipp!

Ich meinte übrigens vorher File#deleteOnExit(), nicht ~OnClose, letztere Methode gibt es gar nicht. Und die erfüllt nun einwandfrei ihre Funktion, nachdem die geöffnete Datei via Shutdown-Hook geschlossen wurde.

Mit Closeable/AutoCloseable bin ich bislang nicht in Berührung gekommen, muss ich zugeben. Wenn ich es richtig verstehe, ruft die VM nur im Falle von AutoCloseable close() automatisch beim Beenden auf? Implementiere ich jedenfalls Closeable und schreibe obigen Code in die close()-Methode, so bewirkt das nichts.
 
K

kneitzel

Gast
Mit Closeable/AutoCloseable bin ich bislang nicht in Berührung gekommen, muss ich zugeben. Wenn ich es richtig verstehe, ruft die VM nur im Falle von AutoCloseable close() automatisch beim Beenden auf? Implementiere ich jedenfalls Closeable und schreibe obigen Code in die close()-Methode, so bewirkt das nichts.
Nein, die VM ruft nichts automatisch auf.

Close ist einfach nur ein Interface, dass besagt, dass es eine Methode close() gibt. Das ist für Nutzer der Klasse dann nur der Hinweis: Hey, wenn Du mich verwendest, dann bitte sei doch so nett und rufe einmal "close()" auf, wenn Du fertig bist.

AutoCloseable ist erst zusammen mit dem "try with resources" gekommen. Bei dem try with resources handelt es sich um ein konstrukt, welches das automatische Schließen mit einbezieht. Also ein
Java:
try (SomeAutoCloseableClass variableName = .... ) {
  // Some Code
}

entspricht ungefähr einem
Java:
{
  SomeAutoCloseableClass variableName;
  try {
      variableName = ....;
    // Some Code
  } finally {
      if (variableName != null) variableName.close();
  }
}

Ansonsten super, dass Du eine funktionierende Lösung gefunden hast und diese mit uns geteilt hast.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
R Delete files before creating new from temp using Java file method Allgemeine Java-Themen 1
G Umgebungsvariabeln auslesen (Path, Temp, oder eigene) Allgemeine Java-Themen 2
kodela StatusBar-Anzeigen auch in Log-Datei ausgeben Allgemeine Java-Themen 3
G Maven Projekt JAR-Datei Allgemeine Java-Themen 6
E XML - Datei Darstellung in IntelliJ als Baum Allgemeine Java-Themen 2
Thomasneuling Java Jar datei erstellen, von Projekt, dass auch Javafx Dateien, FXML Dateien und CSS Dateien, sowie Bilder enthält? Allgemeine Java-Themen 14
D Erste Schritte Mp3 Datei kann nicht von der Festplatte geöffnet werden - mit ChatGPT erstellt Allgemeine Java-Themen 7
J Filenotfoundexception obwohl Datei existiert Allgemeine Java-Themen 6
M Java Überprüfen ob .exe-Datei bereits ausgeführt wird Allgemeine Java-Themen 2
S .exe Datei/Programm auslesen? Allgemeine Java-Themen 2
E Datei verschoben Event Allgemeine Java-Themen 3
D Datei mit "Kohsuke GitHub API" in Repository hochladen Allgemeine Java-Themen 2
S Bookmark HTML Datei einlesen, alle Links erhalten und manche editieren..? (aktuell JSoup) Allgemeine Java-Themen 4
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
G JavaFX Maven Projekt als .exe Datei exportieren Allgemeine Java-Themen 10
J (Geplante) Änderungen an einer Datei vorübergehend speichern und anwenden? Allgemeine Java-Themen 12
Neumi5694 Datei komprimiert Allgemeine Java-Themen 6
_user_q Obfuscate einer .jar-Datei mit ProGuard? Allgemeine Java-Themen 2
_user_q Verknüpfung einer .jar-Datei (liegt z. B. auf dem Desktop) im Autostart-Ordner erstellen? Allgemeine Java-Themen 20
E java mithilfe url .jar datei öffnen Allgemeine Java-Themen 9
E Java .exe Datei mit args starten Allgemeine Java-Themen 2
W Bilder werden in App mit Jar-Datei nicht angezeigt Allgemeine Java-Themen 15
Master3000 Java Datei mehrmals einlesen Allgemeine Java-Themen 4
M Excel Datei Erstellen Allgemeine Java-Themen 2
E Input/Output Eigene Datei mit java öffnen Allgemeine Java-Themen 9
R Sonderzeichen aus Datei einlesen und in Datei ausgeben. Allgemeine Java-Themen 17
Tobero Download .jar von github lädt kaputte Datei runter Allgemeine Java-Themen 3
P Bat Datei in Java ausführen Allgemeine Java-Themen 2
S Verwendet Programmiersprache aus Quellcode - Datei ermitteln Allgemeine Java-Themen 6
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
J Jar-Datei ausführen Allgemeine Java-Themen 7
C Outlook msg-Datei Anhänge extrahieren Allgemeine Java-Themen 2
G Datei aus Ordner wählen, ohne den Dateinamen im Pfad angeben zu müssen Allgemeine Java-Themen 4
G Datei senden via Xmodem an Serial-Port Allgemeine Java-Themen 35
C Wav-Datei aus Jar laden? Allgemeine Java-Themen 11
L Best Practice Zip Datei aktualisieren Allgemeine Java-Themen 1
N Speicherort einer Datei im Explorer ändern Allgemeine Java-Themen 8
H Mehrere PNG-Files in einer Datei Allgemeine Java-Themen 9
Gaudimagspam CSV-Datei auslesen in Java Allgemeine Java-Themen 7
S createTempFile erstellt keine temporäre Datei Allgemeine Java-Themen 13
Hatsi09 Jar datei ausführen verursacht NumberFormatException Allgemeine Java-Themen 9
kodela bestimmten Dateityp immer mit jar-Datei öffnen Allgemeine Java-Themen 17
N Arrayliste in eine Datei speichern Allgemeine Java-Themen 4
B .txt Datei erstellen und auslesen bzw. schreiben Allgemeine Java-Themen 6
J Öffnen eine jar-Datei Allgemeine Java-Themen 11
Dann07 MP3 Datei abspielen funktioniert nicht Allgemeine Java-Themen 6
H ArrayListe in CSV Datei speichern Allgemeine Java-Themen 6
O Aus JAR-Datei erstellte EXE-Datei funktioniert nicht Allgemeine Java-Themen 10
N Txt Datei auslesen. Allgemeine Java-Themen 5
B Datei/Ordner auf Server zugreifen/erstellen Allgemeine Java-Themen 2
MiMa Datei verschieben hat einen Fehler?? Allgemeine Java-Themen 20
MiMa Erstellungsdatum einer Datei Allgemeine Java-Themen 10
O xlsx Datei auslesen mit POI Apache liest keine LEERZELLEN Allgemeine Java-Themen 6
P Input/Output entfernte Datei mit Java öffnen ohne Download Allgemeine Java-Themen 5
O xlsx Datei auslesen mit POI von Apache wirft seltsamen Fehler. Allgemeine Java-Themen 11
J Hilfe, Jar Datei kann nicht ausgeführt werden Allgemeine Java-Themen 2
M Programm erkennt String aus .txt Datei nicht Allgemeine Java-Themen 3
O Java-Applikation tut in Netbeans, als JAR nicht, wegen Pfadangaben einer benötigten Datei Allgemeine Java-Themen 8
J Fehlermeldung bei Ausführung von .jar-Datei Allgemeine Java-Themen 9
J Die Letzte Zahl aus einer Text datei lesen Allgemeine Java-Themen 8
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
M Probleme jar datei. Allgemeine Java-Themen 2
F Datei in String-Array einlesen Allgemeine Java-Themen 8
O docx-Datei erzeugung mit DocXStamper funktioniert nicht Allgemeine Java-Themen 2
T Objekt mit String und Int aus TxT Datei erstellen Allgemeine Java-Themen 23
Bluedaishi Prüfen ob Datei noch geöffnet ist Allgemeine Java-Themen 59
D ODS.Datei öffnet leider in Excel Allgemeine Java-Themen 3
L JavaFX JavaFX Chart in Apache Poi Excel Datei Allgemeine Java-Themen 2
D .txt Datei in .jar Datei speichern Allgemeine Java-Themen 3
ralfb1105 Blöcke aus Datei filtern/suchen und in neue Datei schreiben Allgemeine Java-Themen 10
M Daten aus MatLab Datei lesen Allgemeine Java-Themen 8
L SQL Datei in Eclipse erstellen Allgemeine Java-Themen 3
Drachenbauer Wie sorge ich dafür, dass mein Spiel die ini-Datei in der Resourcen-ordner des Projektes schreibt? Allgemeine Java-Themen 5
Trèfle Excel-Datei nicht speicherbar, da von Java zum Bearbeiten gesperrt. Allgemeine Java-Themen 3
N Datei Zeilenweise Einlesen, Versteckte Zeichen Allgemeine Java-Themen 5
L Excel Datei löscht sich selbst im Programm - Java Allgemeine Java-Themen 3
G Workupload datei mit Java Downloaden Allgemeine Java-Themen 6
H .jar Datei startet nicht richtig bei Doppelklick Allgemeine Java-Themen 11
S Hilfe bei dem Auslesen einer YAML Datei Allgemeine Java-Themen 8
M Java Eclipse- Datei exportieren Allgemeine Java-Themen 5
R jar-Datei funktioniert nicht Allgemeine Java-Themen 2
R .txt Datei einlesen und auf der Konsole ausgeben lassen Allgemeine Java-Themen 11
T Jar Datei nicht ausführbar Allgemeine Java-Themen 6
H jar-Datei mit java.exe anstatt mit javaw.exe ausführen Allgemeine Java-Themen 9
S Datei wird nicht gefunden Thread.currentThread().getContextClassLoader().getResourceAsStream() Allgemeine Java-Themen 1
A Steuerung von Spiel aus Datei lesen Allgemeine Java-Themen 0
Javafan01 .sh datei in Java ausführen Allgemeine Java-Themen 1
MiMa Speichern von Programmeinstellungen in Datei Allgemeine Java-Themen 7
J Ordner und Datei Struktur einer War Datei Allgemeine Java-Themen 1
J XML Datei mit installiertem Programm öffnen Allgemeine Java-Themen 7
L Weg um Datei zuzuordnen? Allgemeine Java-Themen 3
MiMa Datei kann nicht umbenannt oder verschoben werden ?? Allgemeine Java-Themen 17
S Input/Output Beste Möglichkeit einen String in einen Datei zu Schreiben Allgemeine Java-Themen 2
K Erste Schritte Start einer JAR Datei 2 Wege aber einmal nicht die volle Funktionlität Allgemeine Java-Themen 20
J Datei löschen, die Leerzeichen im Pfad hat Allgemeine Java-Themen 5
Aruetiise " in Datei schreiben Allgemeine Java-Themen 2
K Datei (CSV-ähnlich) in Java einlesen & mit teil der Daten Graphen erstellen Allgemeine Java-Themen 9
S Korrekte Pfadangaben damit eine .jar Datei unter Windwos läuft. Allgemeine Java-Themen 24
The Pi NetBeans Bilder in Jar Datei werden nicht angezeigt Allgemeine Java-Themen 7
RalleYTN Audiolänge einer MP3 Datei erhalten ohne diese vollständig zu laden Allgemeine Java-Themen 15

Ähnliche Java Themen

Neue Themen


Oben