Dalam C 11, coretan kod di bawah adalah sah:
struct Cat { Cat(){} }; const Cat cat; std::move(cat);
Ini tingkah laku mungkin kelihatan berlawanan dengan intuisi, kerana menggerakkan objek const membayangkan mengubah keadaannya. Walau bagaimanapun, adalah penting untuk memahami bahawa std::move sebenarnya tidak melakukan sebarang pergerakan.
Apabila anda memanggil std::move pada objek const, pengkompil hanya cuba memindahkan objek. Jika kelas tidak mempunyai pembina yang menerima rujukan const lvalue, ia akan menggunakan pembina salinan tersirat untuk mencipta objek baharu. Ini memastikan bahawa keadaan objek const kekal tidak berubah.
Untuk menunjukkan ini, pertimbangkan kod berikut:
struct Cat { Cat(){} Cat(const Cat&) {std::cout << "COPY";} Cat(Cat&&) {std::cout << "MOVE";} }; int main() { const Cat cat; Cat cat2 = std::move(cat); }
Menjalankan kod ini mencetak "COPY", menunjukkan bahawa pembina salinan telah digunakan sebaliknya daripada pembina bergerak. Ini mengesahkan bahawa std::move tidak mengubah suai objek const.
Walaupun mengalihkan objek const sememangnya tidak betul, ia boleh membawa kepada isu prestasi jika objek mempunyai pembina bergerak. Dalam kes sedemikian, salinan dibuat tanpa perlu. Selain itu, ia boleh menyukarkan lagi untuk menyahpepijat isu yang berkaitan dengan objek bergerak.
std::move boleh digunakan pada objek const kerana ia dilaksanakan sebagai percubaan untuk memindahkan objek bukannya langkah sebenar. Tingkah laku ini tidak melanggar kontrak objek const, dan ia membolehkan fleksibiliti yang lebih besar dalam reka bentuk kod. Walau bagaimanapun, adalah penting untuk mengetahui tentang potensi implikasi prestasi dan cabaran penyahpepijatan yang boleh timbul daripada amalan ini.
Atas ialah kandungan terperinci Mengapa Adakah `std::move` Berfungsi pada Objek `const` dalam C ?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!