Melalukan Objek Sementara sebagai Rujukan dalam C
Dalam C , coretan kod minimum seperti berikut boleh menyebabkan ralat penyusunan pada Linux dan Mac platform:
class Foo { public: Foo(int x) {} }; void ProcessFoo(Foo& foo) { } int main() { ProcessFoo(Foo(42)); return 0; }
Kompilasi Ralat:
Menyusun kod di atas menghasilkan ralat berikut:
newfile.cpp: In function ‘int main()’: newfile.cpp:23:23: error: invalid initialization of non-const reference of type ‘Foo&’ from an rvalue of type ‘Foo’ ProcessFoo(Foo(42)); ^ newfile.cpp:14:6: note: in passing argument 1 of ‘void ProcessFoo(Foo&)’ void ProcessFoo(Foo& foo)
Mengapa Ralat Berlaku:
Dengan reka bentuk, C melarang menghantar objek sementara kepada parameter rujukan bukan const. Sekatan ini bertujuan untuk mengelakkan kemungkinan salah faham dan kesilapan. Apabila fungsi mengisytiharkan parameter rujukan bukan const, ia menandakan niatnya untuk mengubah suai objek dan mengembalikannya kepada pemanggil. Melepasi sementara kepada parameter sedemikian adalah tidak logik, kerana ia akan dimusnahkan sebaik sahaja fungsi kembali.
Penyelesaian:
Untuk menyelesaikan ralat kompilasi ini, pertimbangkan penyelesaian berikut :
Foo foo42(42); ProcessFoo(foo42);
void ProcessFoo(const Foo& foo)
void ProcessFoo(Foo foo)
Mengapa MSVC Membenarkannya:
Tidak jelas mengapa Microsoft Visual Studio (MSVC) membenarkan kod ini dikompil manakala g tidak. Berkemungkinan, MSVC mempunyai tafsiran berbeza tentang piawaian C dalam hal ini. Secara umumnya disyorkan untuk mengikut piawaian untuk memastikan gelagat yang konsisten merentas penyusun yang berbeza.
Atas ialah kandungan terperinci Mengapa Melepasi Objek Sementara kepada Rujukan Bukan Const Gagal dalam C ?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!