Array[n] vs. Array[10]: Der Unterschied zwischen Variableninitialisierung und numerischen Literalen für Array-Größen
In der C-Programmierung Arrays spielen eine entscheidende Rolle bei der Speicherung und dem Abruf von Daten. Allerdings kann es bei der Arbeit mit der Array-Initialisierung bestimmte Fallstricke geben, insbesondere im Zusammenhang mit der Verwendung von Arrays variabler Länge.
Beachten Sie den folgenden Codeausschnitt:
int n = 10; double tenorData[n] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
Dieser Code zielt auf die Initialisierung ab ein Array namens tenorData mit einer Größe, die durch die Variable n bestimmt wird, die auf 10 gesetzt ist. Dieser Ansatz löst jedoch einen Kompilierungsfehler aus, der besagt, dass das Objekt tenorData variabler Größe nicht sein kann auf diese Weise initialisiert.
Der Hauptunterschied in diesem Code liegt in der Verwendung einer Variablen, n, um die Größe des Arrays zu definieren. In C werden Arrays variabler Länge nicht unterstützt, was bedeutet, dass die Größe eines Arrays zur Kompilierzeit eine bekannte Konstante sein muss.
Um dieses Problem zu beheben und das Array erfolgreich zu initialisieren, stehen mehrere Optionen zur Verfügung:
double tenorData[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
const int n = 10; double tenorData[n] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
int n = 10; double* tenorData = new double[n];
Denken Sie daran, den Speicher mit delete [] tenorData freizugeben, wenn Sie mit dem Array fertig sind.
int n = 10; std::vector<double> tenorData(n);
Durch Befolgen dieser Richtlinien können Sie Arrays in C effektiv initialisieren und gleichzeitig die Fallstricke vermeiden, die mit Arrays variabler Länge verbunden sind.
Das obige ist der detaillierte Inhalt vonArray-Initialisierung in C: „Array[n]' vs. „Array[10]' – Was ist der Unterschied?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!