Penyembunyian pembolehubah berlaku apabila subkelas mentakrifkan pembolehubah ahli dengan nama yang sama dengan pembolehubah ahli dalam kelas supernya. Tidak seperti penggantian fungsi, yang menggantikan pelaksanaan, penyembunyian pembolehubah mengaburkan pembolehubah superclass dengan pembolehubah baharu dengan nama yang sama.
Pertimbangkan kod Java berikut:
public class A { public int intVal = 1; public void identifyClass() { System.out.println("I am class A"); } } public class B extends A { public int intVal = 2; public void identifyClass() { System.out.println("I am class B"); } } public class MainClass { public static void main(String[] args) { A a = new A(); B b = new B(); A aRef; aRef = a; System.out.println(aRef.intVal); aRef.identifyClass(); aRef = b; System.out.println(aRef.intVal); aRef.identifyClass(); } }
Output:
1 I am class A 1 I am class B
Dalam contoh ini, pembolehubah intVal ditakrifkan dalam kedua-dua A dan B kelas. Pembolehubah ahli B menyembunyikan satu daripada A. Akibatnya, apabila aRef ditetapkan kepada b, nilai intVal yang diakses masih 1, iaitu nilai lalai intVal A.
Untuk mengakses pembolehubah tersembunyi daripada superclass, kita boleh menggunakan super.var atau ((SuperClass)this).var. Contohnya:
aRef = b; System.out.println(aRef.intVal); // Outputs 1, the value of A's intVal System.out.println(((A)aRef).intVal); // Outputs 2, the value of B's intVal
Dengan menghantar aRef secara eksplisit ke kelas supernya, kita boleh mengakses pembolehubah ahli tersembunyi.
Ingat, penyembunyian pembolehubah membenarkan subkelas mentakrifkan pembolehubah mereka sendiri dengan nama yang sama seperti pembolehubah superclass, tetapi ia tidak mengatasinya sepenuhnya. Kedua-dua pembolehubah wujud bersama, dan pembolehubah subkelas membayangi pembolehubah superclass.
Atas ialah kandungan terperinci Bagaimanakah Pembolehubah Menyembunyikan dalam Java Berbeza daripada Menggantikan Fungsi?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!