Frage zu Speicherverbrauch

Status
Nicht offen für weitere Antworten.

Schumi

Bekanntes Mitglied
Hallo, ich habe eine Frage zum Speicherverbrauch. Und zwar frage ich mich, ob es bei den unteren 3 Beispielen Unterschiede gibt und wenn ja, welche Lösung am besten ist.

1. Es gibt eine feste Array, die in der Klasse initialisiert wird und dann wir häufig eine Methode benutzt, die die Array manipuliert:

Code:
someClass{
	static int [] array = new int [100000];

	main{
		for(i=0;i<somethingBig;i++){call method}
	}
	method(){
		for(int i=0;i<array.length;i++){array[i]=i;}
	}
}


2. Es gibt eine feste Array, die bei jedem Methodenaufruf initialisiert wird.

Code:
someClass{
	static int [] array;

	main{
		for(i=0;i<somethingBig;i++){call method}
	}
	method(){
		array = new int [100000];
		for(int i=0;i<array.length;i++){array[i]=i;}
	}
}

3. Die Array wird bei jedem Methodenaufruf angelegt und initialisiert:

Code:
someClass{
	main{
		for(i=0;i<somethingBig;i++){call method}
	}
	method(){
		int[] array = new int [100000];
		for(int i=0;i<array.length;i++){array[i]=i;}
	}
}

Vielen Dank!
 

Ilja

Bekanntes Mitglied
hängt davon ab, was für ein array das ist und in welchem kontext er verwendet wird ;)

poate mal den code oder erkläre, was das ganze machen soll
 

Mag1c

Top Contributor
Hi,

also Variante eins ist auf jeden Fall erstmal die effizienteste. Hier wird genau einmal das Array angelegt und das wars. Auch der GC sitzt ganz entspannt in der Ecke ;)

bei 2 und 3 wird jedesmal ein neues Array angelegt. Das kostet Zeit. Das alte Array wird verworfen, hier muß also der GC ran. Das kostet noch mehr Zeit.

Also ohne das konkrete Problem zu kennen, würde ich Variante 1 bevorzugen. Mach aber das static weg, falls ist nicht zwingend sein muß.

Gruß
Mag1c
 
B

bygones

Gast
ich behaupte mal bei Methode 3 fliegt dir irgendwann eine OutOfMemory Exception rum, da du immer wieder einen so grossen array intialisierst. Methode 2 find ich unsinnig - warum immer wieder den gleichen array neu initialisieren.....
 

Schumi

Bekanntes Mitglied
Erstmal danke für die schnellen Antworten. Konkret geht es um einen eigene Klasse, die Graphen repräsentiert. Diese benutzt wiederum Klassen für Knoten und Kanten, wobei die Kanten wiederum hauptsächlich aus 2 Knotzen bestehen.

Code:
public class DirectedGraph {
	private Node[] nodes;
	private Arc[] arcs;
	private boolean flag;
}

Code:
public class Node {
	private int id;
	
	private List<Arc> preds; //Eingehende Bögen
	private List<Arc> descs; //Ausgehende Bögen
	private boolean flag;
}

Code:
public class Arc{
	
	private char id;
	private Node pred;
	private Node desc;	
	private double wheight;
	private double capacity;
	private boolean flag;
}



Wir müssen mit recht großen Graphen umgehen (Kantenanzahl ca. 5.000.000) diese werden aus einer Textdatei eingelesen. Mir ist jetzt beim (wohl recht naivem) Einsatz eines Profilers aufgefallen, dass beim erstellen des Graphen neben der genauen Anzahl an Knoten und Kanten noch mehrere Millionen von weiteren (allerdings unbekannten) Arrays erstellt werden und wohl nicht mehr verschwinden. Da das ganze dann nur läuft, wenn ich ihm mehr als 500 MB Speicher (was zu viel ist...) zuweise, bin ich auf Fehlersuche. Die erste Frage war eigentlich nur allgemein gemeint. Im speziellen habe ich z.b. diese Schleife (Sie erstellt die Kanten):
Code:
int i =0;
while( ((line = br.readLine()) != null ) ){
        	   if(!line.equals("")){	//Sicher gehen, keine leeren Zeilen aufzunehmen
        		   	String arcAsString = line;
       				StringTokenizer arcAsToken = new StringTokenizer(arcAsString, "e ");
       				int node1Id = Integer.parseInt(arcAsToken.nextToken());
       				int node2Id = Integer.parseInt(arcAsToken.nextToken());
       				Node node1=nodes[node1Id];
       				Node node2=nodes[node2Id];
       				Arc arc = new Arc(node1, node2);
       				this.arcs[i] = arc;
       				i++;
              }
}
und nun war ich am überlegen, ob es z.B. sinnvoll ist, die ints node*Id und die Nodes eben außerhalb zu erstellen und nur die zuweisungen in der Schleife zu machen.
In den versch. Algorithmen kommt es dann doch häufiger so vor, wie im ersten Post beschrieben, wobei ich zur Zeit die 3. Variante verwende, mit Listen bzw. Arrays, die Knoten oder Kanten erhalten.
 

Schumi

Bekanntes Mitglied
deathbyaclown hat gesagt.:
ich behaupte mal bei Methode 3 fliegt dir irgendwann eine OutOfMemory Exception rum, da du immer wieder einen so grossen array intialisierst. Methode 2 find ich unsinnig - warum immer wieder den gleichen array neu initialisieren.....

ich hat gesagt.:
In den versch. Algorithmen kommt es dann doch häufiger so vor, wie im ersten Post beschrieben, wobei ich zur Zeit die 3. Variante verwende...

:D
Also ich werde mal versuchen, alles nach Methode 1 umzuschreiben und schau mal, ob bzw. in wie weit es sich verbessert.

Edit, nachdem ich gestern den ganzen Abend rumprobiert habe, ist mir dann heute morgen nach dem aufwachen eingefallen, dass es evtl. genau so besser gehen könnte...
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2
H Einfache Frage zur Punktnotation objektname.methode(wert) Java Basics - Anfänger-Themen 2
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 3

Ähnliche Java Themen

Neue Themen


Oben