Arrays allgemeine Frage

Status
Nicht offen für weitere Antworten.

UdoKessler

Mitglied
Hi,

Hab mal wieder eine Verständnisfrage..
In der Javainsel (oder sagt man "auf" der Javainsel?) steht folgendes
über Arrays:


Zitat (von mir etwas umformatiert):

Die Wahrheit über die Array-Initialisierung

So schön die kompakte Initialisierung der Feldelemente ist, so laufzeit- und
speicherintensiv ist sie auch. Da Java eine dynamische Sprache ist, passt das
Konzept der Array-Initialisierung nicht ganz in das Bild. Daher wird die Initialisierung
auch erst zur Laufzeit durchgeführt. Unser Primzahlfeld


int[] primes = { 2, 3, 5, 7, 11, 13 };
wird vom Java-Compiler umgeformt und analog zu Folgendem behandelt:
int[] primes = new int[ 6 ];
primes[ 0 ] = 2;
primes[ 1 ] = 3;
primes[ 2 ] = 5;
primes[ 3 ] = 7;
primes[ 4 ] = 11;
primes[ 5 ] = 13;
(1)Erst nach kurzem Überlegen wird das Ausmaß sichtbar: Zunächst ist es der
Speicherbedarf für die Methoden.

(2)Ist das Feld primes in einer Methode deklariert und mit Werten initialisiert, kostet
die Zuweisung Laufzeit, da wir viele Zugriffe haben, die auch alle schön durch die
Index-Überprüfung gesichert sind.

(3)Da zudem der Bytecode für eine einzelne Methode wegen diverser Beschränkungen
in der JVM nur beschränkt lang sein darf, kann dieser Platz für richtig große Arrays
schnell erschöpft sein. Daher ist davon abzuraten, etwa Bilder oder große Tabellen im
Programmcode zu speichern.

...
..

(4) Tip, Falls doch große Arrays benötigt werden:
Wir verwenden ein statisches Feld (eine Klassenvariable), sodass das Array
nur einmal während des Programmlaufs initialisiert werden muss.
So, hier meine Fragen:

(1) Kann das jemand genauer erklären (in einfachen Worten). Mir ist ja klar,
wieviel Platz Arrays benötigen, lässt sich leicht rechnen. Aber hier bezieht
er sich ja auf Felder in Methoden..Brauchen die da mehr?

(2)Kostet die Zuweisung nicht IMMER Laufzeit, egal wo etwas deklariert wird?
Und die Indexprüfung findet doch auch immer statt, oder nicht?
Und wieso haben wir in einer Methode viele Zugriffe (Also mehr, als bei statischen Feldern, (siehe (4)) ) ?

(3) Habe ich nur der Vollständigkeit wegen mitkopiert.


(4) Meint er damit, daß sie statisch sein sollte, weil das Feld sonst bei jedem
Methodenaufrauf deklariert wird?
Dann könnte ich die Problematik ja verstehen...


Grüße
Udo
 

tfa

Top Contributor
(1) Kann das jemand genauer erklären (in einfachen Worten). Mir ist ja klar,
wieviel Platz Arrays benötigen, lässt sich leicht rechnen. Aber hier bezieht
er sich ja auf Felder in Methoden..Brauchen die da mehr?

Java kennt keine Array-Literale. Solche Array-Definitionen werden vom Java-Compiler in Bytecode-Anweisungen umgewandelt. In diesem Beispiel sieht das dann so aus:

Java:
// Field descriptor #6 [I
  int[] primes;
  
  // Method descriptor #8 ()V
  // Stack: 5, Locals: 1
  public Demo();
     0  aload_0 [this]
     1  invokespecial java.lang.Object() [10]
     4  aload_0 [this]
     5  bipush 6
     7  newarray int [10]
     9  dup
    10  iconst_0
    11  iconst_2
    12  iastore
    13  dup
    14  iconst_1
    15  iconst_3
    16  iastore
    17  dup
    18  iconst_2
    19  iconst_5
    20  iastore
    21  dup
    22  iconst_3
    23  bipush 7
    25  iastore
    26  dup
    27  iconst_4
    28  bipush 11
    30  iastore
    31  dup
    32  iconst_5
    33  bipush 13
    35  iastore
    36  putfield Demo.primes : int[] [12]
    39  return

Ziemlich viel Code für so ein paar Zahlen. Und der muss ausgeführt werden, notfalls bei jedem Methodenaufruf.
Dadurch wird auch die maximale Größe eines so initialisierten Arrays beschränkt. Nicht, weil der Speicherplatz nicht reicht, sondern weil irgendwann der Bytecode die maximale Größe von 64kB pro Methode übersteigt.

(2)Kostet die Zuweisung nicht IMMER Laufzeit, egal wo etwas deklariert wird?
Und die Indexprüfung findet doch auch immer statt, oder nicht?
Und wieso haben wir in einer Methode viele Zugriffe (Also mehr, als bei statischen Feldern, (siehe (4)) ) ?

(4) Meint er damit, daß sie statisch sein sollte, weil das Feld sonst bei jedem
Methodenaufrauf deklariert wird?
Dann könnte ich die Problematik ja verstehen...

Also erstmal glaube ich diesem Buch nicht, dass bei so einer einfachen Arraydefinition jedesmal ein Indexcheck stattfindet. Die VM sollte wirklich in der Lage sein, das wegzuoptimieren. Gerade in solchen einfachen Fällen. Trotzdem kostet die Abarbeitung des Bytecodes natürlich Zeit (siehe oben). Das kann man optimieren, in dem man die Variable statisch macht (wenn dies sinnvoll ist). Dann wird das Array eben nur einmal für die Klasse angelegt und nicht für jedes Objekt oder lokal für jede Methode.


Grüße
Udo[/QUOTE]
 

Painii

Bekanntes Mitglied
(1) Kann das jemand genauer erklären (in einfachen Worten). Mir ist ja klar,
wieviel Platz Arrays benötigen, lässt sich leicht rechnen. Aber hier bezieht
er sich ja auf Felder in Methoden..Brauchen die da mehr?
Naja, schreibe ich:
Java Code:
1
2
3
4
public void doSomething(){ int[] primes = {2,3,5,7,11,13} ... // auf primes rechnen }​

brauch ich für jeden aufruf von doSomething das neu initialisierte Feld.
Ähnliches wenn ichs als Instanzvariable baue (für jedes neue Objekt wird das Array initialisiert).

(4) Meint er damit, daß sie statisch sein sollte, weil das Feld sonst bei jedem
Methodenaufrauf deklariert wird?
Dann könnte ich die Problematik ja verstehen...


Grüße
Udo
Wenn ich etwas statisches habe ( was nicht vom Objekt abhängt, sondern von der Klasse bzw. statisch - unveränderbar), dann reicht es das in der Klasse, nicht in jedem Objekt zu speichern.

Ist in etwa so wie wenn man ein Tafelwerk hat, und 1 Notizzettel - Es würde dauern das ganze erstmal aus dem Tafelwerk abzuschreiben, anstatt es da einfach nur nachzuschauen.
Vor allem wenn dann 20-30 erstmal schreiben kommt da einiges an Zeit (und Papier :p) zusammen was eigentlich verschwendet ist.
Notizzettel (Instanzvariable) kommt nur für Werte zustande, die ich selber veränder.
 
Zuletzt bearbeitet:
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
R Liste und Arrays Java Basics - Anfänger-Themen 12
N mehrdimensionale arrays Java Basics - Anfänger-Themen 12
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Kingdako Wie löse ich eine Mathematische Formel mit Arrays und Schleifen? Java Basics - Anfänger-Themen 32
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
S Hilfe bei Praktischen Aufgaben von Arrays Java Basics - Anfänger-Themen 39
T Objekte mit arrays erstellen Java Basics - Anfänger-Themen 6
M Problem bei verschachtelter for-Schleife bei zweidimensionalen Arrays Java Basics - Anfänger-Themen 3
J Mehrdimensionale Arrays Java Basics - Anfänger-Themen 2
pc pc pc pc pc letztes Element eines Arrays n Java Basics - Anfänger-Themen 3
M Arrays Java Basics - Anfänger-Themen 3
Ostkreuz Wert von Arrays summieren Java Basics - Anfänger-Themen 1
Ostkreuz Summieren von Arrays Java Basics - Anfänger-Themen 4
javaBoon86 Arrays 2 Dimension Werte ausgeben Java Basics - Anfänger-Themen 15
paulen1 Best Practice "Unchecked Assignment" Warnung beim erstellen eines 2D Arrays of Arraylists Java Basics - Anfänger-Themen 2
B bei 2 Arrays Anzahl gleicher Elemente vergleichen? Java Basics - Anfänger-Themen 49
JustAProgrammer Ein Dreieck mit Arrays erstellen Java Basics - Anfänger-Themen 2
TheSepp Nur Arrays ausgeben, die Werte zugewiesen haben. Java Basics - Anfänger-Themen 4
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
ArrayList mit unbekannter Menge an Arrays die Arrays vergleichen Java Basics - Anfänger-Themen 9
D Arrays an replaceAll-Methode übergeben Java Basics - Anfänger-Themen 12
rosima26 Geordnete Arrays ausgeben Java Basics - Anfänger-Themen 31
D Inhalt eines Arrays ausgeben Java Basics - Anfänger-Themen 7
A Jedes zweite Element eines Arrays entfernen Java Basics - Anfänger-Themen 30
C Zwei Arrays addieren und ausgeben Java Basics - Anfänger-Themen 3
E Zinsrechnung mithilfe von Arrays Java Basics - Anfänger-Themen 12
LePetitChat1 Arrays - NullPointerException? Java Basics - Anfänger-Themen 14
H Arrays: Größten Zahlen Unterschied herausfinden Java Basics - Anfänger-Themen 20
H Arrays befüllen Java Basics - Anfänger-Themen 43
C60 Methoden Main-Methode erkennt meine Arrays nicht. Java Basics - Anfänger-Themen 7
D Arrays Java Basics - Anfänger-Themen 9
C Java Arrays - Ausgabe in Methode Java Basics - Anfänger-Themen 12
R While-Loop der die Einträge eines Arrays in umgekehrter Reihenfolge anzeigt Java Basics - Anfänger-Themen 3
N Arrays Java Basics - Anfänger-Themen 5
W n verschiedene Arrays zufällig ausgeben - mit der Random-Klasse? Java Basics - Anfänger-Themen 8
U zwei 2D arrays auf gleich sein überprüfen Java Basics - Anfänger-Themen 14
melaniemueller Lagerverwaltung erstellen - mehrdimensionale Arrays Java Basics - Anfänger-Themen 62
C initialisieren eines arrays richtiger Größe und mit geeignetem Datentyp Java Basics - Anfänger-Themen 26
Bademeister007 Elemente aus zwei verschiedenen Arrays miteinander vergleichen und gegeben falls entfernen Java Basics - Anfänger-Themen 14
A Arrays aufsummieren Java Basics - Anfänger-Themen 11
C Wie 2 Arrays zusammenfügen und sortieren? Java Basics - Anfänger-Themen 11
S Arrays aneinanderketten Java Basics - Anfänger-Themen 20
Sinan Arrays auflisten ohne Wiederholung Java Basics - Anfänger-Themen 28
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
R Werte und Reihenfolge in 2d Arrays vergleichen Java Basics - Anfänger-Themen 5
D Verschlüsslungsaufgabe / Arrays Java Basics - Anfänger-Themen 6
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
L Methode zum invertieren eines Arrays Java Basics - Anfänger-Themen 7
S zweidimensionale char arrays Java Basics - Anfänger-Themen 14
J Methoden Mehrdimensionale Arrays übereinander legen Java Basics - Anfänger-Themen 5
D Verwirrung bei Streams aus primitiven Arrays Java Basics - Anfänger-Themen 2
P Arrays mit verschiedenen Längen miteinander dividieren. Java Basics - Anfänger-Themen 1
P Wie kann ich die Zahlen dieses Arrays dividieren? Java Basics - Anfänger-Themen 2
N 2D Arrays jedes xy vergleichen Java Basics - Anfänger-Themen 7
J Traveling Salesman Problem [Arrays] Java Basics - Anfänger-Themen 9
M Arrays mit mehreren Werten über JOptionPane initialisieren Java Basics - Anfänger-Themen 12
Kawastori Größe eines Arrays bestimmen Java Basics - Anfänger-Themen 13
Zeppi Arrays[i] Java Basics - Anfänger-Themen 7
Lena_2611 Vergleich von Array1 Index mit Array2 Wert und erzeugen eines neues Arrays Java Basics - Anfänger-Themen 8
J B-Sprache mit Arrays ausführen Java Basics - Anfänger-Themen 18
A Teilarrays eines 2D-Arrays sortieren Java Basics - Anfänger-Themen 4
C Arrays - deklarieren, initialisieren? Ist das ein Objekt? Java Basics - Anfänger-Themen 3
K Sudoku mit 2D Arrays Java Basics - Anfänger-Themen 19
T Vertikales Histogramm mit Arrays Java Basics - Anfänger-Themen 3
JD_1998 Arrays einlesen, zwischenspeichern und wieder ausgeben Java Basics - Anfänger-Themen 8
Z Kein überprüfen des gesamten Arrays möglich.(Viergewinnt Spiel) Java Basics - Anfänger-Themen 6
F Arrays: Mathematische Funktion Java Basics - Anfänger-Themen 19
mihe7 Von Datentypen und (mehrdimensionalen) Arrays Java Basics - Anfänger-Themen 4
A Teilen eines Arrays Java Basics - Anfänger-Themen 5
DorFey Sortieren eines mehrdimensionalen Arrays Java Basics - Anfänger-Themen 8
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
L If und else bei 2 Dimensionalen Arrays Java Basics - Anfänger-Themen 8
1 Arrays Java Basics - Anfänger-Themen 7
M Rückgabe eines Arrays Java Basics - Anfänger-Themen 10
L Addition von Arrays über die Parameterliste Java Basics - Anfänger-Themen 11
Z Erste Schritte Indexe innerhalb eines Arrays zusammensählen Java Basics - Anfänger-Themen 14
N Länge eines Arrays in einem Objekt testen Java Basics - Anfänger-Themen 51
S Übergabe von Arrays an Methoden Java Basics - Anfänger-Themen 20
D Collections Arrays in ArrayList abspeichern Java Basics - Anfänger-Themen 6
A Freie Stelle eines Arrays Java Basics - Anfänger-Themen 17
H Ein gegebenes Int Array zu Zwei Arrays zurück geben Java Basics - Anfänger-Themen 6
J 2D Arrays summieren Java Basics - Anfänger-Themen 21
J zwei String Arrays miteinander vergleichen Java Basics - Anfänger-Themen 18
A Java.util.Arrays Java Basics - Anfänger-Themen 15
T Methodenverknüpfung mit Arrays Java Basics - Anfänger-Themen 4
R Zugriff auf den Index eines Arrays, welches ein Objekt ist. Java Basics - Anfänger-Themen 4
F Eine Zahl mit Arrays vergleichen Java Basics - Anfänger-Themen 7
A 2d Arrays aus txt.file einlesen Java Basics - Anfänger-Themen 16
B Arrays Java Basics - Anfänger-Themen 4
P Arrays "automatisch" erstellen lassen Java Basics - Anfänger-Themen 12
B Nur eine bestimmte Anzahl an Arrays ausgeben Java Basics - Anfänger-Themen 9
H Gemeinsame Schnittmenge zweier Arrays ausgeben Java Basics - Anfänger-Themen 12
H Größte Duplikat (Größte Doppelte Wert) eines Arrays ausgeben Java Basics - Anfänger-Themen 9
A Summe des Arrays pd mit alternativer Schleife Java Basics - Anfänger-Themen 2
S Elemente eines Arrays bei Ausgabe auslassen Java Basics - Anfänger-Themen 2
M Verständnisproblem der Rekursion bei Arrays Java Basics - Anfänger-Themen 8
F Mehrdimensionale Arrays Java Basics - Anfänger-Themen 12
M Arrays in Funktion Kopieren und Bearbeiten Java Basics - Anfänger-Themen 4
W Erste Schritte Arrays befüllen und ausgeben Java Basics - Anfänger-Themen 11

Ähnliche Java Themen

Neue Themen


Oben