Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah Saya Boleh Melaksanakan Tatasusunan 2-D yang Diisytiharkan Secara Statik sebagai Ahli Data Kelas dalam C?

Bagaimanakah Saya Boleh Melaksanakan Tatasusunan 2-D yang Diisytiharkan Secara Statik sebagai Ahli Data Kelas dalam C?

Patricia Arquette
Patricia Arquetteasal
2024-12-26 21:44:09119semak imbas

How Can I Implement Statically Declared 2-D Arrays as Class Data Members in C  ?

Array 2-D yang Diisytiharkan Secara Statik dalam C sebagai Ahli Data Kelas

Dalam C , adalah mungkin untuk mencipta kelas yang menggabungkan 2 yang diisytiharkan secara statik tatasusunan -dimensi sebagai ahli data. Pendekatan ini berbeza daripada peruntukan dinamik, di mana memori untuk tatasusunan disimpan secara dinamik semasa masa jalan.

Untuk mencapai matlamat ini, bekas vektor boleh digunakan di dalam kelas bersama-sama dengan mekanisme pengindeksan yang sesuai. Berikut ialah contoh:

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]; }
};

Dalam contoh ini, kelas mengandungi vektor v dan integer nc mewakili bilangan lajur. Pembina digunakan untuk memulakan vektor dengan saiz yang sesuai dan menyimpan bilangan lajur.

Operator [] ditakrifkan semula untuk menyediakan antara muka untuk mengakses elemen tatasusunan dengan cekap. Apabila anda mengakses array2d[r][c], ia secara dalaman mengira indeks dalam vektor berdasarkan r (baris) dan c (lajur). Ini menghapuskan keperluan untuk peruntukan memori yang berasingan untuk tatasusunan.

Contoh penggunaan:

Array2D array2d(2, 3);
array2d[0][0] = 1;
array2d[1][2] = 6;

Kaedah ini membolehkan anda mencipta kelas C yang berkelakuan seperti tatasusunan 2-D sambil mengekalkan faedah peruntukan memori bersebelahan, mengurangkan kehilangan cache dan meningkatkan prestasi.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaksanakan Tatasusunan 2-D yang Diisytiharkan Secara Statik sebagai Ahli Data Kelas dalam C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn