Pengubahan Memori: Pengenalan std::launder dalam C
P0137 memperkenalkan std::launder untuk menangani isu-isu tertentu berkaitan kesatuan, seumur hidup, dan penunjuk dalam C . Templat fungsi ini membenarkan pengubahan memori, proses yang menghalang pengkompil daripada membuat andaian tentang kandungan memori yang diubah suai.
Pengubahan Memori
std::launder melaksanakan memori pencucian, yang menghapuskan sebarang andaian yang mungkin dibuat oleh pengkompil tentang kandungan lokasi memori. Ini amat relevan apabila:
Contoh: Membaktikan Kesatuan yang berterusan Medan
Pertimbangkan contoh ini:
struct X { const int n; }; union U { X x; float f; }; U u = {{ 1 }}; X *p = new (&u.x) X {2};
Memulakan u.x dengan {1} menganggap ahli const n akan sentiasa 1. Walau bagaimanapun, memberikan p kepada objek X baharu dengan n ditetapkan kepada 2 melanggar andaian ini.
Untuk mengakses u.x.n dengan betul selepas pengubahsuaian ini, kami mesti mencuci ingatan:
assert(*std::launder(&u.x.n) == 2); // Will be true
Aplikasi Lain
std::launder juga boleh digunakan dalam situasi di mana jangka hayat berpotensi dilanggar, seperti apabila memperuntukkan yang baharu objek dalam storan objek lama tanpa menggunakan peletakan baharu:
alignas(int) char data[sizeof(int)]; new(&data) int; int *p = std::launder(reinterpret_cast<int*>(&data));
Dengan mencuci penunjuk, kami memintas peraturan seumur hidup yang sebaliknya akan menghalang mengakses objek baharu.
Atas ialah kandungan terperinci Bagaimanakah `std::launder` C Menyelesaikan Pengaliasan Memori dan Isu Sepanjang Hayat?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!