Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah Saya Boleh Mencapai Peruntukan Memori Bersebelahan untuk Tatasusunan 2-D yang Diisytiharkan Secara Statik sebagai Ahli Kelas?
Untuk mengelakkan peruntukan memori dinamik dan memastikan peruntukan memori bersebelahan, anda boleh menggunakan alternatif pendekatan untuk mengisytiharkan tatasusunan 2-D sebagai ahli kelas.
Daripada menggunakan tradisional Tatasusunan 2-D, anda boleh mencipta kelas yang mensimulasikan tingkah laku tatasusunan dengan menggunakan vektor sebagai struktur data asas. Teknik ini menawarkan beberapa kelebihan:
Pertama, vektor menyimpan elemennya secara bersebelahan dalam ingatan, menghapuskan risiko kehilangan cache. Kedua, anda mendapat fleksibiliti untuk menyesuaikan kelas mengikut keperluan khusus anda.
Untuk menunjukkan pendekatan ini, pertimbangkan kod berikut:
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]; } };
Di sini, kelas Array2D mengandungi vektor v dan pembolehubah integer nc mewakili bilangan lajur. Menggunakan pembina, anda boleh memulakan saiz tatasusunan 2-D (NR, NC).
Untuk mengakses elemen tatasusunan, operator[] terlebih beban. Apabila anda memanggil array2d[0][0], ia mengembalikan penunjuk kepada elemen pertama baris pertama.
Dalam fungsi utama:
Array2D array2d(2, 3); array2d[0][0] = 1; array2d[1][2] = 6;
Kod ini memberikan nilai 1 kepada elemen pertama dan 6 kepada elemen terakhir tatasusunan2d.
Pelaksanaan ini menyediakan tatasusunan 2-D yang diisytiharkan secara statik sebagai ahli data bagi kelas, memastikan penyimpanan memori bersebelahan. Ia menawarkan kawalan yang lebih besar ke atas peruntukan memori dan mengelakkan kemungkinan kehilangan cache, menjadikannya pilihan yang cekap untuk aplikasi sensitif prestasi.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mencapai Peruntukan Memori Bersebelahan untuk Tatasusunan 2-D yang Diisytiharkan Secara Statik sebagai Ahli Kelas?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!