Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah Saya Boleh Melaksanakan Tatasusunan 2-D yang Diisytiharkan Secara Statik sebagai Ahli Data Kelas dalam 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!