Memahami Penetapan Semula Rujukan dalam C
Dalam C , lazimnya dinyatakan bahawa rujukan memerlukan pemulaan selepas pengisytiharan dan tidak boleh ditetapkan semula. Walau bagaimanapun, percubaan baru-baru ini telah menimbulkan keraguan tentang tanggapan ini. Mari kita siasat kelakuan penugasan semula rujukan dalam atur cara berikut:
#include <iostream> #include <stdio.h> #include <conio.h> using namespace std; int main() { int i = 5, j = 9; int &ri = i; cout << "ri is : " << ri << "\n"; i = 10; cout << "ri is : " << ri << "\n"; ri = j; // *** Reassignment at Issue *** cout << "ri is : " << ri << "\n"; getch(); return 0; }
Atur cara memberikan rujukan ri kepada pembolehubah integer i, menjadikan ri alias untuk i. Pada mulanya, ri menunjuk kepada nilai 5. Apabila i diubah suai kepada 10, ri mencerminkan perubahan ini dengan betul. Walau bagaimanapun, titik kritikal ialah pernyataan seterusnya: ri = j.
Adakah ini bukan penugasan semula rujukan?
Jawapannya, secara mengejutkan, ialah tidak. ri masih menjadi rujukan kepada i. Untuk menunjukkan ini, anda boleh membandingkan alamat ri dan i: ia adalah sama. Perkara yang anda perhatikan bukanlah penugasan semula rujukan tetapi sebaliknya pengubahsuaian nilai yang disimpan di lokasi memori yang ditunjukkan oleh ri.
Dalam istilah yang lebih mudah, ri = j bersamaan dengan *(&ri) = j , di mana &ri mendapatkan semula alamat memori ri dan * membatalkan rujukan untuk mengakses nilai.
Sebagai perbandingan, jika anda mencipta const int &cri = i, ia akan menghalang sebarang penugasan semula kepada cri, menguatkuasakan sifat malarnya.
Ringkasnya, sementara rujukan tidak boleh ditugaskan semula kepada pembolehubah baharu dalam C , ia boleh digunakan untuk mengubah suai nilai objek yang mereka rujuk, sebagai dilihat dalam program kami.
Atas ialah kandungan terperinci Bolehkah Rujukan Ditugaskan Semula dalam C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!