Statisch deklarierte 2-D-Arrays in C als Klassendatenmitglieder
In C ist es möglich, Klassen zu erstellen, die statisch deklarierte 2 enthalten -dimensionale Arrays als Datenelemente. Dieser Ansatz unterscheidet sich von der dynamischen Zuweisung, bei der Speicher für das Array während der Laufzeit dynamisch reserviert wird.
Um dies zu erreichen, kann innerhalb der Klasse ein Vektorcontainer zusammen mit entsprechenden Indizierungsmechanismen verwendet werden. Hier ist ein Beispiel:
class Array2D { public: vector<int> v; int nc; Array2D(int NR, int NC) : v(NR * NC), nc(NC) {} int* operator[](int r) { return &v[r * nc]; } };
In diesem Beispiel enthält die Klasse einen Vektor v und eine Ganzzahl nc, die die Anzahl der Spalten darstellt. Der Konstruktor wird verwendet, um den Vektor mit der entsprechenden Größe zu initialisieren und die Anzahl der Spalten zu speichern.
Der []-Operator wird neu definiert, um eine Schnittstelle für den effizienten Zugriff auf die Array-Elemente bereitzustellen. Wenn Sie auf array2d[r][c] zugreifen, berechnet es intern den Index im Vektor basierend auf r (Zeile) und c (Spalte). Dadurch entfällt die Notwendigkeit einer separaten Speicherzuweisung für das Array.
Beispielverwendung:
Array2D array2d(2, 3); array2d[0][0] = 1; array2d[1][2] = 6;
Mit dieser Methode können Sie eine C-Klasse erstellen, die sich wie ein 2D-Array verhält und dabei die behält Vorteile der zusammenhängenden Speicherzuweisung, Reduzierung von Cache-Fehlern und Verbesserung der Leistung.
Das obige ist der detaillierte Inhalt vonWie kann ich statisch deklarierte 2D-Arrays als Klassendatenmitglieder in C implementieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!