C++ Dynamische Zuordnung von Arrays mit Beispiel
Was ist ein dynamisches Array?
Ein dynamisches Array ist einem regulären Array ziemlich ähnlich, aber seine Größe kann während der Programmlaufzeit geändert werden. DynamArray-Elemente belegen einen zusammenhängenden Speicherblock.
Nachdem ein Array erstellt wurde, kann seine Größe nicht mehr geändert werden. Ein dynamisches Array ist jedoch anders. Ein dynamisches Array kann seine Größe erweitern, selbst nachdem es gefüllt wurde.
Während der Erstellung eines Arrays wird ihm eine vorbestimmte Speichermenge zugewiesen. Dies ist bei einem dynamischen Array nicht der Fall, da es seine Speichergröße bei Bedarf um einen bestimmten Faktor erhöht.
In diesem C++-Tutorial lernen Sie
- Was ist ein dynamisches Array?
- Faktoren, die sich auf die Leistung dynamischer Arrays auswirken
- Das neue Schlüsselwort
- Initialisieren dynamisch zugewiesener Arrays
- Größenänderung von Arrays
- Arrays dynamisch löschen
Faktoren, die sich auf die Leistung dynamischer Arrays auswirken
Die anfängliche Größe des Arrays und sein Wachstumsfaktor bestimmen seine Leistung. Beachten Sie die folgenden Punkte:
- Wenn ein Array eine kleine Größe und einen kleinen Wachstumsfaktor hat, wird es den Speicher häufiger neu zuweisen. Dadurch wird die Leistung des Arrays verringert.
- Wenn ein Array eine große Größe und einen großen Wachstumsfaktor hat, wird es einen riesigen Teil ungenutzten Speichers haben. Aus diesem Grund können Größenänderungen länger dauern. Dadurch wird die Leistung des Arrays verringert.
Das neue Schlüsselwort
In C++ können wir mit dem Schlüsselwort new ein dynamisches Array erstellen. Die Anzahl der zuzuweisenden Items wird in eckigen Klammern angegeben. Dem sollte der Typname vorangestellt werden. Die angeforderte Stückzahl wird zugeteilt.
Syntax:
Das neue Schlüsselwort hat die folgende Syntax:
pointer_variable = new data_type;
Die Zeigervariable ist der Name der Zeigervariablen.
Der Datentyp muss ein gültiger C++-Datentyp sein.
Das Schlüsselwort gibt dann einen Zeiger auf das erste Element zurück. Nachdem wir das dynamische Array erstellt haben, können wir es mit dem Schlüsselwort delete löschen.
Beispiel 1:
#include<iostream> using namespace std; int main() { int x, n; cout << "Enter the number of items:" << "\n"; cin >>n; int *arr = new int(n); cout << "Enter " << n << " items" << endl; for (x = 0; x < n; x++) { cin >> arr[x]; } cout << "You entered: "; for (x = 0; x < n; x++) { cout << arr[x] << " "; } return 0; }
Ausgabe:
Hier ist ein Screenshot des Codes:
Code-Erklärung:
- Fügen Sie die iostream-Header-Datei in unser Programm ein, um seine Funktionen zu nutzen.
- Nehmen Sie den std-Namensraum in unser Programm auf, um seine Klassen zu verwenden, ohne ihn aufzurufen.
- Rufen Sie die Funktion main() auf. Die Programmlogik sollte innerhalb des Hauptteils der Funktion hinzugefügt werden.
- Deklarieren Sie zwei Integer-Variablen x und n.
- Einen Text auf der Konsole ausgeben, der den Benutzer auffordert, den Wert der Variablen n einzugeben.
- Lesen Sie Benutzereingaben von der Tastatur und weisen Sie sie der Variablen n zu.
- Deklarieren Sie ein Array, das insgesamt n Integer enthalten soll, und weisen Sie es der Zeigervariablen *arr. zu
- Eine Meldung drucken, die den Benutzer auffordert, eine Anzahl von n Elementen einzugeben.
- Verwenden Sie eine for-Schleife, um eine Schleifenvariable x zu erstellen, um die vom Benutzer eingegebenen Elemente zu durchlaufen.
- Lesen Sie die vom Benutzer eingegebenen Elemente und speichern Sie sie im Array arr.
- Ende des Körpers der for-Schleife.
- Text auf der Konsole ausgeben.
- Verwenden Sie eine for-Schleife, um eine Schleifenvariable x zu erstellen, um die Elemente des Arrays zu durchlaufen.
- Geben Sie die Werte aus, die in dem Array namens arr auf der Konsole enthalten sind.
- Ende des Körpers der for-Schleife.
- Das Programm muss nach erfolgreichem Abschluss einen Wert zurückgeben.
- Ende des Hauptteils der main()-Funktion.
HINWEIS:Im obigen Beispiel darf der Benutzer während der Laufzeit eine beliebige Größe für das Array angeben. Das heißt, die Größe des Arrays wird zur Laufzeit bestimmt .
Initialisieren dynamisch zugewiesener Arrays
Es ist einfach, ein dynamisches Array auf 0 zu initialisieren.
Syntax:
int *array{ new int[length]{} };
In der obigen Syntax bezeichnet die Länge die Anzahl der Elemente, die dem Array hinzugefügt werden sollen. Da wir das Array auf 0 initialisieren müssen, sollte dies leer bleiben.
Wir können ein dynamisches Array mit einer Initialisierungsliste initialisieren. Lassen Sie uns ein Beispiel erstellen, das dies demonstriert.
Beispiel 2:
#include <iostream> using namespace std; int main(void) { int x; int *array{ new int[5]{ 10, 7, 15, 3, 11 } }; cout << "Array elements: " << endl; for (x = 0; x < 5; x++) { cout << array[x] << endl; } return 0; }
Ausgabe:
Hier ist ein Screenshot des Codes:
Code-Erklärung:
- Fügen Sie die iostream-Header-Datei in unser Programm ein, um seine Funktionen zu nutzen.
- Fügen Sie den std-Namensraum in unser Programm ein, um seine Klassen zu verwenden, ohne ihn aufzurufen.
- Rufen Sie die Funktion main() auf. Die Programmlogik sollte innerhalb des Hauptteils der Funktion hinzugefügt werden.
- Deklarieren Sie eine Integer-Variable namens x.
- Deklarieren Sie ein dynamisches Array namens array unter Verwendung einer Initialisierungsliste. Das Array enthält 5 ganzzahlige Elemente. Beachten Sie, dass wir den „=“-Operator zwischen der Array-Länge und der Initialisierungsliste nicht verwendet haben.
- Drucken Sie etwas Text auf der Konsole. Das endl ist ein C++-Schlüsselwort, das Endzeile bedeutet. Es bewegt den Cursor zum nächsten Satz.
- Verwenden Sie eine for-Schleife, um die Array-Elemente zu durchlaufen.
- Den Inhalt des Arrays namens array auf der Konsole ausgeben.
- Ende des Körpers der for-Schleife.
- Das Programm muss nach erfolgreichem Abschluss einen Wert zurückgeben.
- Ende des Hauptteils der main()-Funktion.
Größe von Arrays ändern
Die Länge eines dynamischen Arrays wird während der Zuweisungszeit festgelegt.
C++ hat jedoch keinen eingebauten Mechanismus zum Ändern der Größe eines Arrays, sobald es zugewiesen wurde.
Sie können diese Herausforderung jedoch überwinden, indem Sie ein neues Array dynamisch zuweisen, die Elemente kopieren und dann das alte Array löschen.
Hinweis:Diese Technik ist fehleranfällig, versuchen Sie daher, sie zu vermeiden.
Arrays dynamisch löschen
Ein dynamisches Array sollte aus dem Computerspeicher gelöscht werden, sobald es seinen Zweck erfüllt hat. Die delete-Anweisung kann Ihnen dabei helfen. Der freigegebene Speicherplatz kann dann verwendet werden, um einen anderen Datensatz zu halten. Aber selbst wenn Sie das dynamische Array nicht aus dem Computerspeicher löschen, wird es automatisch gelöscht, sobald das Programm beendet wird.
Hinweis:
Um ein dynamisches Array aus dem Computerspeicher zu löschen, sollten Sie delete[] anstelle von delete verwenden. Das [] weist die CPU an, mehrere Variablen statt einer Variablen zu löschen. Die Verwendung von delete anstelle von delete[] beim Umgang mit einem dynamischen Array kann zu Problemen führen. Beispiele für solche Probleme sind Speicherlecks, Datenbeschädigung, Abstürze usw.
Beispiel 3:
#include<iostream> using namespace std; int main() { int x, n; cout << "How many numbers will you type?" << "\n"; cin >>n; int *arr = new int(n); cout << "Enter " << n << " numbers" << endl; for (x = 0; x < n; x++) { cin >> arr[x]; } cout << "You typed: "; for (x = 0; x < n; x++) { cout << arr[x] << " "; } cout << endl; delete [] arr; return 0; }
Ausgabe:
Hier ist ein Screenshot des Codes:
Code-Erklärung:
- Integrieren Sie die iostream-Header-Datei in unser Programm, um deren Funktionen zu nutzen.
- Nehmen Sie den std-Namensraum in unser Programm auf, um seine Klassen zu verwenden, ohne ihn aufzurufen.
- Rufen Sie die Funktion main() auf. Die Programmlogik sollte innerhalb des Hauptteils der Funktion hinzugefügt werden.
- Deklarieren Sie zwei Variablen x und n vom Integer-Datentyp.
- Drucken Sie etwas Text auf der Konsole. Der Text fordert den Benutzer auf, die Anzahl der Zahlen anzugeben, die er eingeben wird.
- Lesen Sie Benutzereingaben von der Tastatur. Der Eingabewert wird der Variablen n zugewiesen.
- Deklarieren Sie eine Zeigervariable *arr. Das Array arr reserviert etwas Speicher, um insgesamt n Ganzzahlen zu speichern.
- Eine Meldung auf der Konsole ausgeben, die den Benutzer auffordert, n Zahlen einzugeben.
- Erstellen Sie eine for-Schleife und die Schleifenvariable x, um die vom Benutzer eingegebenen Zahlen zu durchlaufen.
- Lesen Sie die vom Benutzer eingegebenen Zahlen und speichern Sie sie im Array arr.
- Ende des Körpers der for-Schleife.
- Text auf der Konsole ausgeben.
- Verwenden Sie eine for-Schleife und die Schleifenvariable x, um über den Inhalt des Arrays arr zu iterieren.
- Die Werte des Arrays arr auf der Konsole ausgeben.
- Ende des Körpers der for-Schleife.
- Eine leere Zeile auf der Konsole ausgeben.
- Speicher des Arrays arr. freigeben
- Das Programm gibt einen Wert zurück, wenn es erfolgreich abgeschlossen wurde.
- Ende des Hauptteils der main()-Funktion.
Zusammenfassung:
- Reguläre Arrays haben eine feste Größe. Sie können ihre einmal deklarierte Größe nicht mehr ändern.
- Bei diesen Arten von Arrays wird die Speichergröße während der Kompilierzeit bestimmt.
- Dynamische Arrays sind anders. Ihre Größe kann während der Laufzeit geändert werden.
- In dynamischen Arrays wird die Größe zur Laufzeit bestimmt.
- Dynamische Arrays in C++ werden mit dem Schlüsselwort new deklariert.
- Wir verwenden eckige Klammern, um die Anzahl der Elemente anzugeben, die im dynamischen Array gespeichert werden sollen.
- Sobald wir mit dem Array fertig sind, können wir den Speicher mit dem delete-Operator freigeben.
- Verwenden Sie den Löschoperator mit [], um den Speicher aller Array-Elemente freizugeben.
- Eine Löschung ohne [] gibt den Speicher von nur einem einzigen Element frei.
- Es gibt keinen integrierten Mechanismus zum Ändern der Größe von C++-Arrays.
- Um ein Array mit einem Listeninitialisierer zu initialisieren, verwenden wir den „=“-Operator nicht.
C Sprache
- C#-Arrays
- Übergeben eines Arrays an eine Funktion in der C++-Programmierung
- C Dynamische Speicherzuweisung
- Arrays in C++ | Erklären | Initialisieren | Zeiger auf Array-Beispiele
- Operatoren in C++ mit Beispiel:Was ist, Typen und Programme
- C++ Switch Case-Anweisung mit BEISPIEL
- C++-Struktur mit Beispiel
- std::list in C++ mit Beispiel
- Unterschied zwischen Struktur und Klasse:Erklärt mit C++-Beispiel
- Auswahlsortierung im Java-Programm mit Beispiel