Rumah > pembangunan bahagian belakang > C++ > Bagaimanakah `std::vector` Mengendalikan Agihan Semula Tatasusunan Dinamik dalam C ?

Bagaimanakah `std::vector` Mengendalikan Agihan Semula Tatasusunan Dinamik dalam C ?

Linda Hamilton
Lepaskan: 2024-11-26 14:12:10
asal
973 orang telah melayarinya

How Does `std::vector` Handle Dynamic Array Reallocation in C  ?

Peruntukan Semula dalam C : Meneroka std::vector Solution

Dalam C , ketiadaan fungsi realloc eksplisit mungkin menimbulkan kebimbangan apabila anda perlu mengembangkan penimbal dinamik. Walau bagaimanapun, kelas templat std::vector menyediakan penyelesaian yang mudah dan cekap untuk masalah ini.

Memahami Alokasi Semula

Peruntukan Semula melibatkan pelarasan saiz blok memori yang diperuntukkan sebelum ini . Dalam C , ini dicapai melalui fungsi realloc. Walau bagaimanapun, C memperkenalkan kelas std::vector, yang menguruskan tatasusunan dinamik dan menawarkan kaedah yang lebih mudah dan selamat untuk pengagihan semula.

Menggunakan std::vector untuk Penempatan Semula

Untuk memperuntukkan tatasusunan n elemen dengan nilai awal ditetapkan kepada 0, anda biasanya akan gunakan:

Type* t = (Type*)malloc(sizeof(Type)*n);
memset(t, 0, sizeof(Type)*m);
Salin selepas log masuk

Dengan std::vector, ini boleh dipermudahkan kepada:

std::vector<Type> t(n, 0);
Salin selepas log masuk

Untuk membesarkan tatasusunan untuk menampung elemen n2, anda akan menggunakan:

t = (Type*)realloc(t, sizeof(Type) * n2);
Salin selepas log masuk

Dengan std::vector, ini dicapai oleh:

t.resize(n2);
Salin selepas log masuk

Melalukan Penunjuk kepada Fungsi

Apabila menghantar penunjuk kepada fungsi, anda boleh menggunakan &t[0] dan bukannya t. Ini sah kerana std::vector menyokong penggunaan elemennya sebagai penunjuk kepada tatasusunan asas.

Foo(&t[0])
Salin selepas log masuk

Kesimpulan

Dengan menggunakan std::vector, anda boleh mengagihkan semula memori dinamik dengan mudah dan selamat dalam C . Ini menghapuskan keperluan untuk pengurusan memori yang jelas, menjadikan kod anda lebih ringkas dan kurang terdedah kepada ralat.

Atas ialah kandungan terperinci Bagaimanakah `std::vector` Mengendalikan Agihan Semula Tatasusunan Dinamik dalam C ?. 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