Rumah > pembangunan bahagian belakang > C++ > Adakah Elemen Vektor STL Kekal Berturut-turut dalam Ingatan Selepas Saiz semula?

Adakah Elemen Vektor STL Kekal Berturut-turut dalam Ingatan Selepas Saiz semula?

Susan Sarandon
Lepaskan: 2024-11-16 07:26:03
asal
586 orang telah melayarinya

Do STL Vector Elements Remain Consecutive in Memory After Resizing?

Keterkaitan Storan Elemen Vektor STL

Apabila bekerja dengan vektor STL, adalah penting untuk memahami susun atur memori elemennya. Soalan biasa timbul: jika vektor telah diubah saiznya, bolehkah kita dengan selamat menganggap bahawa unsur-unsurnya disimpan bersebelahan dalam ingatan?

Analisis

Piawaian C 03 (23.2 .4.1) memberikan jawapan:

The elements of a vector are stored contiguously, meaning that if v is a vector where T is some
type other than bool, then it obeys the identity &amp;v[n] == &amp;v[0] + n for all 0 <= n < v.size().
Salin selepas log masuk

Dalam istilah yang lebih mudah, ini bermakna alamat elemen pertama (&v[0]) bagi vektor adalah sama dengan alamat elemen ke-nnya ( &v[n]) tambah offset bagi n. Ini terpakai kepada vektor yang mengandungi jenis data selain daripada boolean.

Contoh

Pertimbangkan kod berikut:

vector<char> vc(100);
// do some stuff with vc
vc.resize(200);
char* p = &vc[0];
// do stuff with *p
Salin selepas log masuk

Mengikut standard, kami boleh mengandaikan dengan selamat bahawa selepas mengubah saiz vektor, alamat yang disimpan dalam p akan memberikan akses bersebelahan kepada semua 200 elemen vektor. Ini kerana elemen vektor dijamin akan disimpan satu demi satu dalam ingatan, membolehkan traversal dan akses yang cekap.

Awas

Walau bagaimanapun, ia penting untuk ambil perhatian bahawa apabila menambah elemen pada vektor, storannya mungkin diagihkan semula. Ini boleh membatalkan sebarang penunjuk atau iterator sedia ada kepada elemen vektor, jadi penting untuk mengambil kira perkara ini apabila bekerja dengan vektor.

Atas ialah kandungan terperinci Adakah Elemen Vektor STL Kekal Berturut-turut dalam Ingatan Selepas Saiz semula?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan