Menetapkan Semula Rujukan dalam C
Dalam C , rujukan sering digambarkan sebagai pengikatan tidak berubah kepada alamat memori. Walau bagaimanapun, soalan baru-baru ini telah menimbulkan keraguan tentang pemahaman ini. Untuk meneroka topik ini, mari kita periksa program C berikut:
#include <iostream> int main() { int i = 5, j = 9; int &ri = i; std::cout << "ri is: " << ri << '\n'; i = 10; std::cout << "ri is: " << ri << '\n'; ri = j; // Is this not reassigning the reference? std::cout << "ri is: " << ri << '\n'; return 0; }
Kod ini berjaya disusun, dan outputnya ialah:
ri is: 5 ri is: 10 ri is: 9
Persoalannya timbul: bukankah tugasan itu ri = j; bercanggah dengan tanggapan rujukan tidak berubah?
Tidak, ri masih merujuk kepada i. Ini boleh disahkan dengan mencetak alamat ri dan i dan memerhatikan bahawa ia adalah sama.
Apa yang sebenarnya berlaku ialah rujukan ri digunakan untuk mengubah suai nilai i. Memberikan nilai baharu kepada ri sememangnya dilarang, kerana rujukan itu tidak boleh diubah dan mesti sentiasa menunjuk ke lokasi memori yang sama.
Sebagai perbandingan, pertimbangkan kod berikut:
const int &cri = i;
Ini kod tidak akan membenarkan tugasan untuk cri, kerana ia merujuk kepada pemalar. Ini menunjukkan bahawa walaupun rujukan tidak boleh ditugaskan semula ke lokasi memori baharu, ia masih boleh digunakan untuk mengubah suai nilai pada alamat yang dirujuk, dengan syarat nilai itu boleh berubah.
Kesimpulannya, ri = j; tugasan dalam atur cara asal bukanlah penugasan semula rujukan itu sendiri, sebaliknya pengubahsuaian nilai yang dirujuknya.
Atas ialah kandungan terperinci Bolehkah Rujukan C Ditugaskan Semula?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!