Rumah >pembangunan bahagian belakang >C++ >Mengapa Pengendali C `std::vector` `[]` Tidak Membuang Ralat untuk Akses Luar Sempadan?
Vektor Mengakses Di Luar Sempadan Tanpa Ralat
Dalam C , std::vector ialah bekas terbina dalam yang menyimpan koleksi elemen daripada jenis yang sama. Ia menyediakan peruntukan memori yang dinamik, membolehkan saiz semula yang cekap dan penambahan elemen. Walau bagaimanapun, apabila mengakses elemen melebihi saiz vektor, tingkah laku yang tidak dijangka mungkin berlaku.
Berbeza dengan fungsi ahli at(), yang menimbulkan ralat apabila mengakses elemen luar sempadan, pengendali kurungan segi empat sama ([]) berkelakuan berbeza. Apabila menggunakan [], percubaan untuk mengakses indeks melebihi saiz vektor tidak menyebabkan ralat. Sebaliknya, ia mengembalikan nilai yang tidak dimulakan atau sampah seolah-olah elemen itu wujud.
Pertimbangkan contoh berikut:
struct Element { std::vector<double> face; }; int main() { Element elm; // Add six elements to elm.face ... std::cout << elm.face.size() << std::endl; // Outputs 6 std::cout << elm.face[6] << std::endl; // Outputs an unexpected number }
Dalam kod ini, muka vektor dalam struct Elemen mengandungi enam elemen. Apabila mengakses muka[6], yang berada di luar sempadan, vektor tidak membuang ralat. Sebaliknya, ia mengembalikan nilai rawak yang terdapat dalam lokasi memori yang ditunjukkan oleh indeks.
Tingkah laku ini boleh membawa kepada hasil yang tidak dapat diramalkan dan salah, terutamanya apabila bergantung pada saiz vektor untuk memastikan pengindeksan yang betul. Adalah penting untuk berhati-hati apabila menggunakan pengendali kurungan segi empat sama, dan menyemak sempadan sebelum mengakses elemen untuk mengelakkan hasil yang tidak ditentukan.
Atas ialah kandungan terperinci Mengapa Pengendali C `std::vector` `[]` Tidak Membuang Ralat untuk Akses Luar Sempadan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!