Ralat: Melepasi Objek Sementara sebagai Rujukan
Dalam C , cuba melepasi objek sementara sebagai rujukan bukan const mungkin menghadapi ralat kompilasi . Ini berlaku apabila fungsi menjangkakan parameter rujukan dan digunakan dengan objek sementara.
Sebagai contoh, pertimbangkan kod berikut:
class Foo { public: Foo(int x) {}; }; void ProcessFoo(Foo& foo) { } int main() { ProcessFoo(Foo(42)); return 0; }
Kod ini berjaya dikompil pada beberapa penyusun, seperti Visual Studio, tetapi gagal dengan ralat pada orang lain, seperti GCC. Mesej ralat biasanya menunjukkan permulaan yang tidak sah bagi parameter rujukan bukan const daripada jenis rvalue.
Penyelesaian
Untuk menyelesaikan isu ini, terdapat tiga penyelesaian biasa:
Buat pembolehubah sementara untuk seruan ProcessFoo:
Foo foo42(42); ProcessFoo(foo42);
Jadikan ProcessFoo mengambil rujukan const:
void ProcessFoo(const Foo& foo) { }
Benarkan ProcessFoo menerima Foo mengikut nilai:
void ProcessFoo(Foo foo) { }
Sebab untuk Ralat Penyusunan
C melarang menghantar objek sementara kepada rujukan bukan const untuk mengelakkan operasi yang tidak bermakna. Fungsi yang mengambil rujukan bukan const mengharapkan untuk mengubah suai parameter dan mengembalikannya kepada pemanggil. Melepasi objek sementara mengalahkan tujuan ini kerana ia tidak boleh diubah suai dan dikembalikan.
Perbezaan Keserasian
Sebab mengapa kod asal dikompilasi pada Visual Studio tetapi bukan pada GCC ialah berkemungkinan disebabkan oleh perbezaan dalam konfigurasi pengkompil. Visual Studio mungkin membenarkan menghantar sementara kepada rujukan bukan const sebagai pengoptimuman atau untuk keserasian ke belakang. Walau bagaimanapun, pengkompil C moden lebih suka menguatkuasakan semantik bahasa dengan ketat, seperti yang dilaksanakan dalam GCC.
Atas ialah kandungan terperinci Mengapa Melepasi Objek Sementara sebagai Rujukan Bukan Const dalam C Menyebabkan Ralat Penyusunan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!