Melalukan Argumen Rujukan Objek kepada Fungsi Benang: Isu Pembina
Dalam C 11, antara muka std::thread membenarkan penciptaan benang ringan. Satu tugas biasa ialah menghantar argumen kepada fungsi utas ini, tetapi kesukaran mungkin timbul apabila cuba menghantar rujukan objek.
Pertimbangkan contoh berikut:
void foo(int &i) { std::cout << i << std::endl; } int k = 10; std::thread t(foo, k);
Kod ini berjaya menyusun dan berjalan, sebagai integer disalin ke dalam fungsi benang. Walau bagaimanapun, menghantar rujukan objek std::ostream tidak menyusun:
void foo(std::ostream &os) { os << "This should be printed to os" << std::endl; } std::thread t(foo, std::cout);
Ralat menunjukkan pembina yang hilang atau tidak boleh diakses.
Penyelesaian: Menggunakan std::ref
Benang menyalin hujahnya secara lalai. Untuk meluluskan rujukan secara eksplisit, pendekatan alternatif diperlukan. Di sinilah std::ref masuk. Ia membungkus rujukan objek dalam pembungkus nilai-semantik.
Dengan menggunakan std::ref, fungsi benang menerima salinan pembungkus, tetapi rujukan yang dibalut kekal yang sama:
std::thread t(foo, std::ref(std::cout));
Ini membolehkan fungsi benang mengakses dan mengubah suai objek asal, membenarkan objek yang diingini kefungsian.
Adalah penting untuk ambil perhatian bahawa objek yang dirujuk mesti kekal boleh diakses sepanjang pelaksanaan urutan. Jika ia dipadamkan atau diubah suai sebelum urutan selesai, tingkah laku atau ranap sistem yang tidak dijangka mungkin berlaku.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melewati Rujukan Objek dengan Selamat kepada Benang C 11?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!