Input/Output Datei in den Speicher lesen.

Lybrial

Bekanntes Mitglied
Hallo,

wie kann ich eine Datei komplett einlesen (also in den Speicher)
und dann Zeile für Zeile durchgehen?

Es sind sehr große Dateien. Eine Datei hat so ca. 100 GB.
Ich möchte eine Datei nach der anderen abarbeiten.

Also eine Datei in den Speicher lesen, Zeile für Zeile durchgehen,
nächste Datei in den Speicher lesen.
 

Lybrial

Bekanntes Mitglied
Ich weiß nicht sonderlich viel über Java, aber ich weiß das diese
Aussage nicht stimmen kann!

Wenn ich z.B. ganz primitiv mit einem BufferedReader über die
Datei gehe und jede Zeile an einen String anfüge habe ich die
gesamte Datei im Speicher, da sie im String gespeichert ist.

:oops:
 

Thallius

Top Contributor
Noch einmal. 100GB RAM hat kein Rechner. Selbst wenn du sie einlesen könntest, müßte er sie ins virtuelle RAM lesen, was bedeutet er schreibt sie wieder auf die Platte. Wo liegt dann also der Vorteil? Es wird dadurch nicht schneller als wenn du es zeilenweise einliest.

Gruß

Claus
 

kaoZ

Top Contributor
Ich habe 3 TB Ram zur Verfügung....

Klingt nach Großrechner ^^

Was genau soll denn der Vorteil sein wenn du alles in den Ram lädst ? bzw. was bezweckst du damit ?

BTW. da du wenn du alles an einen String anfügst, z.B per Stringbuilder oder "+" Operator könnte es gut sein das der Heap deiner JVM dafür nicht ausreicht. Soweit ich weiß liegt dieser maximal zwischen 1536 to 2048 mb , und diese dürften dann relativ schnell voll sein bei einem 100GB großen Objekt, bzw. Objekten.

Wichtig ist dann auch noch ob 32 oder 64 Bit OS und JVM .

zu 100% sicher bin ich mir da aber nicht , hatte dies nur irgendwann mal gelesen.
 
Zuletzt bearbeitet:

Lybrial

Bekanntes Mitglied
Ich habe ein Zeitproblem.

Derzeit lese ich über einen BufferedReader Zeile für Zeile aus der Datei
in einen String ein, verarbeite ihn und hole mir die nächste Zeile.
Die Datei hat insgesamt über 1.5 Milliarden Zeilen.

Um 1 Millionen Zeilen zu verarbeiten benötigt das Programm derzeit
15 Minuten. Das ist zu lange. Viel zu lange.

Ich muss nun versuchen zu optimieren wo es geht. Ich erhoffe mir
eine Zeitersparnis, wenn die Datei im RAM liegt, da Festplattenzugriffe
eigentlich immer teuer sind.
 

Thallius

Top Contributor
Es bleiben aber doch die gleichen Festplatten Zugriffe. Egal ob du alles auf einmal liest oder Zeile für Zeile. Da wirst du nichts sparen können. Klar nicht unbedingt Zeilenweise einlesen aber wenn du 64MB Blöcken oder so ließt dann sollte es wurscht sein.

Kannst Du doch ganz einfach ausprobieren. Lies einfach mal immer größere Blöcke ein und und schau wie sich die Zeit verhält. Ich denke irgendwann wird sie der Geschwindigkeitsgewinn gegen 0 annähern.

Ich denke eher, was immer du da auch machst, hast du eher ein Konzept Problem. Es werden ja nicht jeden Tag Millionen neue Zeilen hinzukommen oder? Und selbst wenn, dann must du halt mehrmals am Tag deine Software laufen lassen und immer nur die neuen Zeilen auswerten.
Wiso läuft das Ganze nicht auf einer Datenbank? Dann gäbe es das Problem überhaupt nicht.
100GB große Textdateien sind für mich eigentlich grundsätzlich ein absolutes NoGo.


Gruß

Claus
 
Zuletzt bearbeitet:

Lybrial

Bekanntes Mitglied
So ein Mist!

Die JVM limitiert das ganze tatsächlich auf 2GB.
Dann muss ich mir was anderes einfallen lassen.

Danke soweit.

Und als Antwort zu meinem Vorposter:

Die 100GB großen Dateien sollen in eine Datenbank verlegt werden.
Und falls du dich fragst wer die 100GB große Datei angelegt hat:

Das war google! Der Freebase Datenbank Dump ist eigentlich sogar
weit über 300GB groß. Ich hab ihn durch das löschen überflüssiger
Informationen schon auf 100GB "komprimiert".
 
Zuletzt bearbeitet:

kaoZ

Top Contributor
Vielleicht kannst du ja hiermit was Anfagen , hier ist ein Link enthalten wie man wohl auch auf einem 32Bit System weit über 32GB an Speicher für Objekte durch Sogenannte 'oops' also sprich Pointer nutzen kann

Heap Size_Stackoverflow.com

unter 6. mit dem Grünen Haken, habs mir jetzt nicht genauer angeschaut ;)

Du landest im Grunde hier :

Oracle - Compressed Oops
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Eine Datei im Speicher erneut laden(?) Allgemeine Java-Themen 1
S Jar Datei mit mehr Speicher starten Allgemeine Java-Themen 2
S JAR Datei, mehr Speicher bereitstellen Allgemeine Java-Themen 5
O Datei im Speicher halten Allgemeine Java-Themen 4
C RAM Speicher in Datei auslagern (Java Swapping) Allgemeine Java-Themen 4
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
I Temp-Datei wird nicht gelöscht Allgemeine Java-Themen 12
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

Ähnliche Java Themen

Neue Themen


Oben