3.5 Mio. Objekte

J

julari

Gast
HAllo zusammen!

Ich habe lange in Google geschaut, aber keine Antwort auf mein Problem gefunden.
Ich habe folgendes grosses Objekt:
Java:
public class Feature extends Spectrum.Peak 
{
    

    public float time = 0;
    public float mass = 0;
    public int charge = 0;
    protected boolean accurateMZ = false;  
    public float kl = -1.0F;
    public float dist = -1.0F;
    public int peaks = 1;
    public boolean skippedPeaks = false;
    public int chargeStates = 1;
    protected String description;
    public int scanFirst;
    public int scanLast;
    public float totalIntensity = 0F;
    public float proportional_intensity=0F;
    public int scanCount = -1;
    public static float MZ_RANGE = .04f;
    public boolean fits_4_6_pattern;
    public boolean fits_0_10_pattern;
    public boolean overlap;
    public int running_scan_number;
    public Feature[] observed_isotopic_pattern;
    public float[] theoretical_isotopic_pattern;
    public int observed_isotopic_pattern_length;
    public int[] exclude_index;
    public boolean rejected;
    public int index;
    public double observed_isotopic_pattern_intensity_sum;
    public float sn;
    public boolean FeatureFragmented;
  }

Davon erzeuge ich nach einlesen eines XML files etwa 3.5 Mio. Stück!
Es gibt natürlich einen memory error in Java (heap space).

Ich muss, um Berechnunge zu machen, diese Features (welche geordnet sind zB nach Masse) komplett durchgehen.
Was kann ich tun um das Speicherproblem zu lösen?

Wenn ich die 3.5 Mio Features auf der Festplatte abspeichere statt in einer ArrayList, dann habe ich eigentlich auch keinen Vorteil,oder? Denn dann muss ich alles auch wieder einlesen und habe anschliessend wieder eine ArrayList<Features> Struktur mit 3.5 Mio. Einträgen.

Oder sehe ich das falsch?
Was kann also tun, um die Daten sukkzessive und am Stück durchzugehen, ohne sie im Hauptspeicher halten zu müssen?

Vielen Dank!
 
Zuletzt bearbeitet von einem Moderator:
J

julari

Gast
Hallo!

Vielen Dank. So wie ich es aber auch drehe, ich brauche denke ich schon alle Objekte, denn wenn ich nur ein Teil selektiere, dann fehlt der andere.
Wie würde es denn funktionieren, wenn ich alle Objekte brauche?
 

langhaar!

Bekanntes Mitglied
Hallo!

Vielen Dank. So wie ich es aber auch drehe, ich brauche denke ich schon alle Objekte, denn wenn ich nur ein Teil selektiere, dann fehlt der andere.
Wie würde es denn funktionieren, wenn ich alle Objekte brauche?

Das hast du falsch verstanden. Du brauchst zwar alle Objekte, aber nicht gleichzeitig.
Wenn du z.B. eine Summe bilden willst, dann brauchst du die laufenden Summe und ein(!) Objekt, von dem du Daten hinzuaddierst.
 
J

julari

Gast
Puh! Geht das evtl. auch anders als dass ich den XML parser umschreiben muss? Den habe ich nämlich nicht selber geschrieben....

Ich verstehe schon, dass man am besten immer nur einen Teil der Daten in den Speicher laden soll. Problem: Ich weiss vorher immer nicht, wie viele der 3.5 Mio. Features ich einladen soll. Nehme ich zB 1000 Stück, dann kann es sein, dass der 1001. Feature auch noch dazugehört. Das kann ich vorher nicht sehen, wie die Features zusammenhängen.

Es ist so schwer zu erklären......

Das Ausgabgsfile schaut in etwas so aus:
<Scan1>
<Feature1>
<Feature2>
<Feature3>
<Feature4>
......
Scan2>
<Feature1>
<Feature2>
<Feature3>
<Feature4>
......
...........
...........
Scan4000>
<Feature1>
<Feature2>
<Feature3>
<Feature4>
......

Wenn ich daraus die Features herausparse, komme ich auf 3.5 Mio Features in einer ArrayList.
 

langhaar!

Bekanntes Mitglied
Puh! Geht das evtl. auch anders als dass ich den XML parser umschreiben muss? Den habe ich nämlich nicht selber geschrieben....

KLar, indem du eine DB nimmst. Dann brauchst du den Parser nicht umschreiben, weil du keinen mehr benutzt :D

EDIT
Blödsinn. Auch dann musst du den Parser umschreiben, um beim Einlesen die Daten in die DB abzulegen.
Da du nicht alle Daten auf einmal laden kannst, sehe ich keine Möglichkeit, dass du nicht an den Parser musst.

Ich verstehe schon, dass man am besten immer nur einen Teil der Daten in den Speicher laden soll. Problem: Ich weiss vorher immer nicht, wie viele der 3.5 Mio. Features ich einladen soll. Nehme ich zB 1000 Stück, dann kann es sein, dass der 1001. Feature auch noch dazugehört.

Du sollst auch nicht 1000 Stück laden, sondern immer nur 1!
Dann vergleichst du, ob die Features zusammenpassen.

Erst wenn deine Daten nicht sequentiel gelesen werden können, wirst du wohl auf eine DB ausweichen müssen.
 
Zuletzt bearbeitet:
S

SlaterB

Gast
Ich verstehe schon, dass man am besten immer nur einen Teil der Daten in den Speicher laden soll. Problem: Ich weiss vorher immer nicht, wie viele der 3.5 Mio. Features ich einladen soll. Nehme ich zB 1000 Stück, dann kann es sein, dass der 1001. Feature auch noch dazugehört. Das kann ich vorher nicht sehen, wie die Features zusammenhängen.

Es ist so schwer zu erklären......
ohne Erklärung kann dir aber niemand helfen,
gut möglich dass du aus irgendeinem Grund (allein schon um umfangreichere Code-Änderungen zu vermeiden) besser 1001 Objekte gleichzeitig in den Speicher holst,
das könnte vollkommen in akzeptablen Regionen sein wenn der Speicher für hunderttausende reicht,

du kannst dafür deine Verarbeitung mehr oder weniger intelligent machen,
z.B. immer noch einzeln einlesen aber die Objete sammeln,
wenn in der Liste schon x Objekte drin sind, das nächste Objekt y sich aber vom vorherigen unterscheidet,
dann in diesem Moment die gemeinsame Verarbeitung der x Objekte starten, danach die Liste leeren und y einfügen
sowie weiter machen, nächstes Objekt laden

auf solchem Wege könntest du beliebige zusammengehörige Teilmengen verarbeiten,
falls sie in Reihenfolge vorliegen,
und natürlich abgesehen von dem Fall dass eine solche Teilmenge den Speicher übersteigt
 

bERt0r

Top Contributor
Da dein Objekt ja nur Eigenschaften und keine Methoden besitzt bist du sicher mit einer Datenbank am besten bedient. Wenn du damit wenig Erfahrung hast, schau dir mal H2 Database Engine an. SQL-mäßig solltest du mit Grundkenntnissen auskommen.
 
I

irgendjemand

Gast
dein ansatz ist falsch

natürlich brauchst du mit sicherheit ALLE deine objekte ... IRGENDWANN ... aber NIE gleichzeitig

als beispiel sollte man vielleicht mal die arbeitsweise eines rechners in seinen zugrundeliegenden mathematischen fähigkeiten beschrieben

ein computer hat eine gewisse anzahl von operationen *arithmetisch und logisch > ALU , fließkommazahlen > FPU* die er auf eine gewissen anzahl von eingangssignalen anwenden kann ...
du kannst zwar ewiglange befehlsketten schreiben ... in der regel werden aber nie mehr als 3 werte gleichzeitig gebraucht : 1tes register , 2tes register , operation die auszuführen ist

heißt also : egal welche operation du ausführen willst ... du kannst diese *linear gesehen* alle nach ein ander durchführen *mal von multi-threading auf mehrkern-cpus abgesehen* ... und genau das versuchen dir hier alle klar zu machen ...

du musst nicht alle 3,5mio objekte GLEICHZEITIG im speicher halter ... weil du um diese alle gleichzeitig verarbeiten zu können auch min 3,5mio prozessoren bräuchtest ... die du mit sicherheit nicht hast ..

was also zu tun ist das du sequentiell arbeitest und immer nur so wenig objekte wie möglich im RAM hast ... den rest schreibst du raus auf die platte ...
also hast du maximal 4 werte im RAM ... objekt1 , objekt2 , die anweisung was mit den beiden objekten gemacht werden soll und schließlich das ergebnis ... nach dieser verarbeitung schreibst du das ergebnis auch raus auf die platte und entlädst die objekte so das der RAM freigegeben wird ...
 

fastjack

Top Contributor
Die GC wird Dir wenig helfen, außer wenn Du Objekte nach der Berechnung aus Deiner Collection entfernst, ansonsten hast Du nunmal 3.5M Objekte im Speicher. Die VM wird dann aber die GC irgendwann alleine starten. Meine Erfahrung zeigte, das die GC immer gestartet wird, wenn ich System.gc() aufrufe, aber das ist nicht garantiert.

Beim Parsen zu berechnen ist vielleicht sogar ideal für Dich, außer wenn das ganze dynamisch sein soll, z.B. in einer GUI verwendet wird. Wenn die Berechnungsarten fest sind, würde ich mehrere Berechnungen beim Parsen hintereinander machen machen, also einmal parsen, dabei mehrere Berechnungen anstoßen (daten dabei in verschiedenen Objekten halten).

Ansonsten, wenn es dynamisch sein soll, ab mit den Daten in eine DB.
 

ARadauer

Top Contributor
Ganz einfach: Java mehr Speicher geben... ich hab hier einen 8 GB rechner 3.5 Mio Objekte... lol... kein problem

java -Xmx2048m -jar deinJar.jar
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Initialisierung von Klassen-Objekte Java Basics - Anfänger-Themen 47
W Objekte erzeugen Httprequest oder Httpclient Java Basics - Anfänger-Themen 3
G Kann Arrays.stream() auch auf Objekte angewant werden? Java Basics - Anfänger-Themen 40
krgewb Über Objekt, das Objekte desselben Typs enthält iterieren Java Basics - Anfänger-Themen 5
I Zapier -> wie werden Objekte gespeichert? Java Basics - Anfänger-Themen 10
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
K Hab ich dass so richtig erklärt (Objekte und Referenzen)? Java Basics - Anfänger-Themen 5
J Objekte in JSON speichern?? Java Basics - Anfänger-Themen 1
I Objekte in ShareProject speichern um später zu nutzen Java Basics - Anfänger-Themen 4
J Objekte Java Basics - Anfänger-Themen 22
T Objekte mit arrays erstellen Java Basics - Anfänger-Themen 6
Hzrfa Objekte, Referenz Java Basics - Anfänger-Themen 5
T 3D Objekte verarbeiten Java Basics - Anfänger-Themen 2
N Welche Objekte kann man zu einem Set hinzufügen Java Basics - Anfänger-Themen 4
I XML einlesen und Objekte bekommen Java Basics - Anfänger-Themen 2
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
Encera Zugriff auf Map-Objekte Java Basics - Anfänger-Themen 3
E Objekte löschen Java Basics - Anfänger-Themen 9
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
Encera Auf Objekte aus anderer Klassen zugreifen Java Basics - Anfänger-Themen 20
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
B Objekte verschwinden beim Übersetzen Java Basics - Anfänger-Themen 5
D Zwei verschiedene Intellij Projekte, wie benutze ich wechselseitig objekte Java Basics - Anfänger-Themen 8
E Rekursiv Objekte erzeugen - geht das? Java Basics - Anfänger-Themen 2
T Collections Sind Subklassen-Objekte in Listen mit Generics erlaubt? Java Basics - Anfänger-Themen 16
F Aus eingelesener Datei korrekt Objekte erzeugen Java Basics - Anfänger-Themen 5
G Übergeordnete Objekte abrufen Java Basics - Anfänger-Themen 9
B Bin komplett am verzweifeln :( Verkettete Liste die Objekte hat Attribut auslesen Java Basics - Anfänger-Themen 14
A Objekte mit Parametern in eine Liste packen Java Basics - Anfänger-Themen 19
B Objekte, bspw. konkret Arraylists,manuell aus Speicher löschen? Java Basics - Anfänger-Themen 70
S Objekte von zwei klassen in zwei verschiedene Textdateien schreiben Java Basics - Anfänger-Themen 5
D Wie Objekte im JFrame frei bewegen lassen? Java Basics - Anfänger-Themen 3
Spandeli8 Erzeugte Objekte gegenüber Bildern hervorheben in Java Processing Java Basics - Anfänger-Themen 1
J Zwei Objekte vergleichen Java Basics - Anfänger-Themen 8
L Werte von Objekte addieren Java Basics - Anfänger-Themen 14
U Objekte in LinkedList löschen und editieren Java Basics - Anfänger-Themen 14
W Objekte über Scanner Input; ToString Probleme... Java Basics - Anfänger-Themen 4
J Problem mit einer Methode, die beliebig viele Objekte in Array speichern soll Java Basics - Anfänger-Themen 6
G Methoden Informationen aus zwei Objekte bekommen? Java Basics - Anfänger-Themen 6
P Globale Objekte Java Basics - Anfänger-Themen 2
C Nachträglich neue grafische Objekte hinzufügen Java Basics - Anfänger-Themen 7
D Interaktion zweier Objekte Java Basics - Anfänger-Themen 5
M Objekte in Array speichern und ausgeben Java Basics - Anfänger-Themen 17
S Objekte indiziert erstellen Java Basics - Anfänger-Themen 27
M Warum dürfen Objekte einer Klasse auf statische Variablen dieser Klasse referenzieren? Java Basics - Anfänger-Themen 10
M Objekte mittels equals vergleichen Java Basics - Anfänger-Themen 14
C Fernseher-Aufgabe (Methoden, Klassen und Objekte) Java Basics - Anfänger-Themen 63
N Typebound Objekte einer Arraylist hinzufügen Java Basics - Anfänger-Themen 7
A (Objekte Java Basics - Anfänger-Themen 6
Y Klassen Klassen und Objekte Java Basics - Anfänger-Themen 3
Y Klassen Klassen und Objekte mit set und get Java Basics - Anfänger-Themen 0
U Objekte in einer LinkedList sortieren Java Basics - Anfänger-Themen 5
N Methode um Objekte einer Liste hinzuzufügen Java Basics - Anfänger-Themen 1
G Java Objekte auf Duplikate testen Java Basics - Anfänger-Themen 4
B Neue Liste erstellen, wenn Objekte bestimmte Referenz hat / Gruppierung von Einträgen Java Basics - Anfänger-Themen 12
M Implementieren einer Datenstruktur, welche nur 5 Objekte speichert Java Basics - Anfänger-Themen 3
M Objekte miteinander vergleichen Java Basics - Anfänger-Themen 18
C Verschiedene Objekte in einer Liste speichern Java Basics - Anfänger-Themen 6
J Java GUI- Objekte Position per Quelltext bestimmen Java Basics - Anfänger-Themen 4
G Objekte in Methoden? Java Basics - Anfänger-Themen 13
H Auf Objekte bzw Variabeln aus einer anderen Methode zugreifen Java Basics - Anfänger-Themen 7
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
K Boolean in einer Methode um 2 Objekte zu vergleichen Java Basics - Anfänger-Themen 12
I Objekte Hilfe Java Basics - Anfänger-Themen 8
G Klassen und Objekte Java Basics - Anfänger-Themen 2
W Verschachtelte Objekte wieder auspacken Java Basics - Anfänger-Themen 3
R Attribute mehrerer Objekte ausgeben Java Basics - Anfänger-Themen 3
C Objekte und Konstruktoren Java Basics - Anfänger-Themen 2
F Erstellen zweier Objekte mit dem selben Inhalt Java Basics - Anfänger-Themen 1
O ObjectOutputStream Anzahl Objekte festhalten Java Basics - Anfänger-Themen 17
R Objekte aus Array als String + kommasepariert speichern Java Basics - Anfänger-Themen 12
X Objekte einer ArrayList richtig ausgeben? Java Basics - Anfänger-Themen 8
J Best Practice Dateiinhalte validieren und auf Objekte mappen Java Basics - Anfänger-Themen 3
B Automatisch Objekte erzeugen mit verschiedenen Namen Java Basics - Anfänger-Themen 4
der_Schokomuffin Hilfe gesucht beim Thema Objekte übergeben! Java Basics - Anfänger-Themen 2
S Konstruktor, Objekte Java Basics - Anfänger-Themen 4
PaperHat Objekte in Array vergleichen Java Basics - Anfänger-Themen 9
B HTML Code / Seite auslesen und JAVA Objekte erstellen Java Basics - Anfänger-Themen 12
PaperHat Programmieraufgabe - Objekte in Objekten Java Basics - Anfänger-Themen 2
E Methode mit Parametern um Objekte zu übergeben Java Basics - Anfänger-Themen 4
V Collections Objekte einer ArrayList in der main() ausgeben Java Basics - Anfänger-Themen 9
T Klassen Klassenübergreifende Objekte erstellen lassen Java Basics - Anfänger-Themen 5
A Objekte verknüpfen Java Basics - Anfänger-Themen 2
M Objekte mit einer Schleife mehrmals erzeugen Java Basics - Anfänger-Themen 17
B Klassen Alle Unter-Objekte durchlaufen in der Hauptklasse Java Basics - Anfänger-Themen 10
B Objekte zählen/ Vererbung/ Kopplung/ Interface/ Abstract Class Java Basics - Anfänger-Themen 5
S Zählen der Zeiger auf Objekte Java Basics - Anfänger-Themen 35
J Methoden Equals Methode für Integer und Objekte überschreiben? Java Basics - Anfänger-Themen 9
B Erste Schritte Objekte von JFrame der Fenstergröße anpassen Java Basics - Anfänger-Themen 3
M Klassen und Objekte Java Basics - Anfänger-Themen 2
J Objekte und Abstrakte Klassen Java Basics - Anfänger-Themen 2
J Array Objekte einer Klasse zuordnen Java Basics - Anfänger-Themen 15
H Interface Objekte speichern und laden (serialisieren/deserialisieren) Java Basics - Anfänger-Themen 1
Orkanson Objekte in ein Array einfügen Java Basics - Anfänger-Themen 5
X Objekte in ArrayList einfügen Java Basics - Anfänger-Themen 10
L Vorherige Objekte zählen und ausgeben Java Basics - Anfänger-Themen 11
Orkanson Objekte und Klassen Java Basics - Anfänger-Themen 8
R Objekte zur Laufzeit in Schleife erzeugen und in ArrayList ablegen Java Basics - Anfänger-Themen 4
D Objekte-Fragen Java Basics - Anfänger-Themen 1
T Objekte in der Methode Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben