Rumah >pembangunan bahagian belakang >C++ >Adakah selamat untuk menganggap keterkaitan memori dalam vektor STL?
Keterkaitan Memori dalam STL Vectors: A Safe Assumption
Isu yang dihadapi berkenaan dengan susunan penyimpanan elemen dalam vektor STL. Secara khusus, persoalan timbul sama ada adalah bijak untuk menganggap bahawa elemen vektor disimpan bersebelahan dalam ingatan, membolehkan untuk mendapatkan semula elemen berikutnya dengan selamat menggunakan alamat elemen pertama.
Mengikut piawaian C 03 ( 23.2.4.1), andaian ini memang benar:
"Unsur vektor ialah disimpan bersebelahan, bermakna jika v ialah vektor dengan T ialah beberapa jenis selain bool, maka ia mematuhi identiti &v[n] == &v[0] n untuk semua 0 <= n < "
Ini menunjukkan bahawa selepas mengubah saiz vektor, alamat elemen pertamanya boleh digunakan dengan selamat untuk mengakses elemen yang tinggal secara berurutan. Formula &vc[n] == &vc[0] n menyediakan mekanisme yang boleh dipercayai untuk mengira offset memori bagi elemen seterusnya.
Walau bagaimanapun, adalah penting untuk ambil perhatian bahawa andaian ini kekal sah hanya sehingga vektor diperuntukkan semula . Menambah elemen pada vektor boleh mencetuskan operasi pengagihan semula, menjadikan mana-mana penunjuk dan iterator sedia ada tidak sah. Oleh itu, adalah penting untuk berhati-hati apabila berurusan dengan vektor yang tertakluk kepada potensi pengagihan semula.
Atas ialah kandungan terperinci Adakah selamat untuk menganggap keterkaitan memori dalam vektor STL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!