Heim > Artikel > Backend-Entwicklung > Vergleich von dynamischen Arrays und festen Arrays
Dynamische Arrays und statische Arrays sind zwei verschiedene Arten von Arrays, die häufig in Programmen verwendet werden. Sie weisen deutliche Unterschiede in der Speicherverwaltung, Größe und Nutzungsflexibilität auf.
Ein statisches Array ist ein Array, das zur Kompilierungszeit definiert und Speicherplatz zugewiesen wird. Seine Größe wird zur Kompilierzeit bestimmt und kann nicht geändert werden. Die Größe eines statischen Arrays wird normalerweise zum Zeitpunkt der Deklaration angegeben, zum Beispiel: int arr[10]. Bei der Verwendung statischer Arrays weist der Compiler ihnen eine feste Größe an Speicherplatz zu, was dazu führt, dass ihre Größe zur Laufzeit nicht geändert wird. Das bedeutet, dass die Größe eines statischen Arrays nicht dynamisch vergrößert oder verkleinert werden kann.
Im Gegensatz dazu sind dynamische Arrays Arrays, die zur Laufzeit erstellt und zerstört werden und deren Größe bei Bedarf angepasst werden kann. Die Größe eines dynamischen Arrays wird nicht zur Kompilierzeit bestimmt, sondern der Speicherplatz wird zur Laufzeit nach Bedarf zugewiesen und freigegeben. Die Größe eines dynamischen Arrays kann mithilfe bestimmter Funktionen wie malloc() und realloc() dynamisch angepasst werden. Bei der Verwendung dynamischer Arrays kann die Größe des Arrays dynamisch an den tatsächlichen Bedarf angepasst werden.
Das Folgende ist ein spezifisches Codebeispiel, um den Unterschied zwischen dynamischen Arrays und statischen Arrays zu veranschaulichen:
Statisches Array-Beispiel:
#include <iostream> int main() { int arr[5]; // 静态数组声明 for(int i = 0; i < 5; i++) { arr[i] = i; // 为静态数组赋值 } for(int i = 0; i < 5; i++) { std::cout << arr[i] << " "; // 输出静态数组的元素 } return 0; }
Hier wird ein statisches Array arr der Größe 5 deklariert und einem Wert zugewiesen. Die Größe eines statischen Arrays wird zur Kompilierzeit bestimmt und kann zur Laufzeit nicht geändert werden.
Beispiel für ein dynamisches Array:
#include <iostream> #include <cstdlib> int main() { int size; std::cout << "请输入动态数组的大小:"; std::cin >> size; int* arr = (int*) malloc(size * sizeof(int)); // 动态数组的创建 for(int i = 0; i < size; i++) { arr[i] = i; // 为动态数组赋值 } for(int i = 0; i < size; i++) { std::cout << arr[i] << " "; // 输出动态数组的元素 } free(arr); // 动态数组的销毁 return 0; }
Hier wird die Größe des dynamischen Arrays durch Benutzereingaben ermittelt und dann die Funktion malloc() verwendet, um dynamisch ein dynamisches Array arr vom Typ int mit der Größe size zu erstellen. Die Größe dynamischer Arrays kann basierend auf der Eingabe angepasst werden. Verwenden Sie abschließend die Funktion free(), um den vom dynamischen Array belegten Speicherplatz freizugeben.
Wie Sie dem obigen Beispiel entnehmen können, liegt der Unterschied zwischen dynamischen Arrays und statischen Arrays in der Art und Weise, wie die Größe bestimmt wird und wie der Speicher verwaltet wird. Die Größe eines statischen Arrays wird zur Kompilierzeit bestimmt und kann nicht geändert werden, während die Größe eines dynamischen Arrays zur Laufzeit nach Bedarf angepasst werden kann. Die Erstellung und Zerstörung dynamischer Arrays erfordert den Einsatz spezifischer Funktionen zur Speicherverwaltung, während die Speicherverwaltung statischer Arrays automatisch vom Compiler übernommen wird. Daher müssen wir in praktischen Anwendungen entsprechend den spezifischen Anforderungen entscheiden, ob wir statische Arrays oder dynamische Arrays verwenden möchten.
Das obige ist der detaillierte Inhalt vonVergleich von dynamischen Arrays und festen Arrays. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!