Speicherbereich von Array nicht zusammenhängend?

affot

Mitglied
Hallo,

ich habe gerade gelernt, dass der Inhalt eines Arrays in Java nicht in einem zusammenhängenden Speicherbereich im HS abgelegt wird.
Das wundert mich sehr, denn gerade das ist doch durch den direkten indizierten Zugriff der entscheidende Vorteil von Arrays gegenüber Listen. Warum sollte ich denn dann überhaupt ein Array benutzen und nicht immer einfach eine ArrayList? Wo sind hier die Unterschiede?
 

LimDul

Top Contributor
Eine der Ideen von Java ist, das von der Hardware abstrahiert. Dementsprechend sollte man sich um sowas eigentlich nie Gedanken machen müssen. Was zwischen Java-Code und Maschinencode passiert ist viel schwarze Magie (aka - da spielen so viele Komponenten mit, dass man schwer sinnvolle Aussagen treffen kann, alleine die Tatsache das es verschiedene JREs gibt, die ggf. Dinge unterschiedlich machen, Hotspot Compiler die Code on the fly kompilieren bei Bedarf, etc.).

Daher würde mich mal interessieren, wo die Aussage herstammt. Und es ist ein Unterschied zwischen "Werden nie zusammenhängt abgelegt und müssen nicht zusammenhängend abgelegt werden". Das eine verbietet es nicht, fordert es aber nicht immer - während das andere es verbieten würde.
 

mihe7

Top Contributor
dass der Inhalt eines Arrays in Java nicht in einem zusammenhängenden Speicherbereich im HS abgelegt wird.
Zu den Ausführungen von @LimDul kommt hinzu, dass das ggf. auch von der Definition von "Inhalt eines Arrays" und "zusammenhängender Speicherbereich des Hauptspeichers" abhängig ist.

Die Aussage stimmt praktisch immer, wenn Objekte als "Inhalt eines Arrays" gesehen werden. Dann befinden sich im Array lediglich die Referenzen auf die Objekte. Bzgl. des zusammenhängenden Speichers ist das so eine Sache, denn der Adressraum ist nur logisch vom Betriebssystem zur Vefügung gestellt. Wo das Zeug tatsächlich im Speicher landet, ist eine ganz andere Frage.

Nachtrag:
Warum sollte ich denn dann überhaupt ein Array benutzen und nicht immer einfach eine ArrayList? Wo sind hier die Unterschiede?
Der Zugriff auf die Elemente eines Arrays erfolgt auf wesentlich niedrigerer Ebene. Bei der ArrayList ist ein Methodenaufruf dazwischen.
 

affot

Mitglied
Also woher ich diese Aussage habe: aus einem Skript für Datenstrukturen & Algorithmen:
"In Abschnitt 2.2 werden wir sehen, dass Java im Gegensatz zu vielen anderen Programmiersprachen nur die Basisdatentypen als zusammenhängenden Block im Hauptspeicher repräsentiert. Arrays und Objekte hingegen werden ohne Einflussmöglichkeit des Programmierers immer durch einen Zeiger dargestellt, der auf den eigentlichen Wert verweist. Insofern sind Arrays oder Klassen nicht als atomare Objekte repräsentiert. Im Vorgriff auf Abschnitt 2.2 sei hier jedoch schon einmal darauf hingewiesen, dass dennoch auch in Java alle Array-Zugriffe in O(1) Zeit erfolgen, da auch im Falle von Nicht-Basisdatentypen als Array-Komponenten nur genau eine Indirektion bei einem Zugriff verfolgt werden muss."

Aber ganz so pauschal kann man das ja anscheinend nicht sagen wie ich es interpretiere.
 
K

kneitzel

Gast
Also die Aussage "Inhalt eines Arrays in Java nicht in einem zusammenhängenden Speicherbereich im HS abgelegt wird" sehe ich hier nicht in dem zitierten Text.

Der Text beschreibt lediglich nur die Unterscheidung in "Basisdatentypen" und "Array/Objekte". In der Java Language Spezification (JLS) ist die Trennung zwischen: Primitive Types und Reference Types.

Ein Basisdatentyp ist halt sowas wie ein einfacher Wert. Das ist ein Block von x Bytes und diese Daten werden immer übergeben.

Bei einem Reference Type hast Du aber halt die Referenz ("Zeiger") auf einen Speicherbereich. Somit hast du zwei Speicherbereiche:
1. Die Referenz, die in der Variable gespeichert wird.
2. Die eigentliche Instanz, auf die referenziert wird.

Ich würde in meinem jugendlichen Leichtsinn ohne eine Prüfung in den konkreten Implementationen der JVMs aber behaupten, dass die eigentlichen Instanzen aber sehr wohl einen zusammenhängenden Speicherbereich haben. Und der Text hat (in meinen Augen etwas unglücklich) lediglich diese Trennung in Referenz und eigentlicher Instanz gemeint.

So wäre zumindest jetzt erst einmal meine Sicht auf diese Thematik.
 
K

kneitzel

Gast
Die sog. "(doppelt) verkettete Liste" (engl. "(doubly) linked list)) scheint hier als Stichwort aber auch passen.
Dann sind wir aber von den Arrays weg.

Wenn man auf reine Objekte geht, dann würde dann ggf. besser passen, dass eine Instanz ja Referenzen auf andere Instanzen beinhalten kann (Also so wie die Nodes der verketteten Liste auch, nur eben allgemeiner). Dann hätte man ein komplexes Objekt, welches an vielen Stellen im Speicher liegt.
 

affot

Mitglied
Also die Aussage "Inhalt eines Arrays in Java nicht in einem zusammenhängenden Speicherbereich im HS abgelegt wird" sehe ich hier nicht in dem zitierten Text.

Ja da hast du Recht. Ich hatte das irgendwie aufgrund des Satzes davor interpretiert ("dass Java im Gegensatz zu vielen anderen Programmiersprachen nur die Basisdatentypen als zusammenhängenden Block im Hauptspeicher repräsentiert." ), dass es logischerweise dann bei den anderen Typen NICHT so ist.
Irgendwie echt nicht clever formuliert das Ganze.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Array verkleinern Java Basics - Anfänger-Themen 2
J Array aus Numberfield Eingaben Java Basics - Anfänger-Themen 7
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
Ü Zweidimensionales Array in der ersten Zeile deklarieren Java Basics - Anfänger-Themen 13
Thomas Uppe 2D Array Reihenfolge vermischen Java Basics - Anfänger-Themen 4
T array auslesen Java Basics - Anfänger-Themen 2
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
moini Auf Array aus Superklasse zugreifen? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
M NullPointerException: Cannot read the array length because "this.Kinder" is null Java Basics - Anfänger-Themen 1
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Proxy Chars vor array übergabe toLowerUpcase Java Basics - Anfänger-Themen 14
iAmFaiinez Primzahlen Tester ohne Array Java Basics - Anfänger-Themen 4
S array 2 dimensional treppe Java Basics - Anfänger-Themen 3
S Array 2x2 Blöcke mit 0 und 1 Java Basics - Anfänger-Themen 10
C Array von Klassen Java Basics - Anfänger-Themen 2
julian0507 2Dim-Array Spaltensummen Java Basics - Anfänger-Themen 1
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
Proxy Stack erweitern mit neuem Array falls der alte voll ist!? Java Basics - Anfänger-Themen 5
E Array, nächste Zahl zur 5 ausgeben, wie? Java Basics - Anfänger-Themen 42
J Array.list vergleichen Java Basics - Anfänger-Themen 1
W Java-Code mit Array Java Basics - Anfänger-Themen 14
D Reflections & Generisches Array Java Basics - Anfänger-Themen 4
T Array Java Basics - Anfänger-Themen 2
T Array Java Basics - Anfänger-Themen 15
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Images aus einem Array ausgeben Java Basics - Anfänger-Themen 3
R 2d Array individuell machen Java Basics - Anfänger-Themen 4
D 2D Char Array into String Java Basics - Anfänger-Themen 2
J Array Median bestimmen Java Basics - Anfänger-Themen 6
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
S Prüfen ob ein zweidimensionales Array rechteckig ist Java Basics - Anfänger-Themen 4
N Array Java Basics - Anfänger-Themen 1
J Array Mittleren Wert bestimmen Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
S Inhalte aus Array vergleichen und Max ausgeben Java Basics - Anfänger-Themen 3
M 2d array ohne längen anlegen Java Basics - Anfänger-Themen 4
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
S Ausgeben wie oft ein Wert in einem Array vorkommt Java Basics - Anfänger-Themen 7
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
O 2 Dimensionales Array Java Basics - Anfänger-Themen 6
M Bubble Sort - Int[] Array sortieren Java Basics - Anfänger-Themen 2
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
B Array nach Elementwerten sortieren? Java Basics - Anfänger-Themen 1
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
L Gegebenes Array sortieren, indem zufällige Zahlenpaare aus Array ausgewählt werden Java Basics - Anfänger-Themen 14
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
N Array beim erstellen mit Werten füllen Java Basics - Anfänger-Themen 6
C Java Array Struktur, welche ist wann besser? Java Basics - Anfänger-Themen 12
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
E Durch Muster in Array iterieren Java Basics - Anfänger-Themen 3
L Frage zum Array Java Basics - Anfänger-Themen 1
C 2D Array Ausgabe mit for-Schleife i,j Java Basics - Anfänger-Themen 4
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
P Array vom Typ Klasse Java Basics - Anfänger-Themen 18
Lion.King Array deklarieren und initialisieren Java Basics - Anfänger-Themen 5
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
AkiJou Zeile in 2d Array löschen Java Basics - Anfänger-Themen 2
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
A Elemente in einem Array Java Basics - Anfänger-Themen 5
A Vorkommende Farben ermittel und als Array zurückgeben Java Basics - Anfänger-Themen 7
AhmadSlack Array Java Basics - Anfänger-Themen 7
Jambolo Kartenhand Array Java Basics - Anfänger-Themen 14
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
S Eine Variable in einem Array speichern Java Basics - Anfänger-Themen 5
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
krgewb byte-Array, das ein Bild repräsentiert Java Basics - Anfänger-Themen 1
1 Array rekursiv durchlaufen Java Basics - Anfänger-Themen 8
I Methoden Wieso wird mein Array "a" verändert und meine Variable "a" nicht? Java Basics - Anfänger-Themen 4
EykS 3D Druckdatei basierend auf 3D Array? Java Basics - Anfänger-Themen 3
sserio Array funktioniert nicht Java Basics - Anfänger-Themen 2
sserio Iterierung über ein zweidimensionales Array Java Basics - Anfänger-Themen 16
sserio Zweidimensionales Array [][] wird untereinander ausgegeben Java Basics - Anfänger-Themen 14
Chris.089 2 Werte im Array tauschen Java Basics - Anfänger-Themen 6
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
L Unbekanntes Problem mit 2d Array Java Basics - Anfänger-Themen 6
L Gridmuster in einem Array Java Basics - Anfänger-Themen 2
sgtcoopa Array übergeben Schleife Java Basics - Anfänger-Themen 0
B Compiler-Fehler Array aus Objekten übergeben Java Basics - Anfänger-Themen 7
padde479 Array Multiplikation der ersten n Zahlen Java Basics - Anfänger-Themen 7
G zweidimensionales int Array sortieren Java Basics - Anfänger-Themen 57
W Array ausgeben Java Basics - Anfänger-Themen 29

Ähnliche Java Themen

Neue Themen


Oben