Invokasi Kaedah Terlebih Beban: Mengutamakan Jenis Parameter Sebenar
Mekanisme lebihan kaedah Java memilih pelaksanaan yang paling sesuai berdasarkan jenis parameter yang diisytiharkan. Walau bagaimanapun, salah tanggapan yang lazim ialah ia turut mempertimbangkan jenis sebenar semasa peleraian beban lampau.
Cabaran
Pertimbangkan coretan kod berikut:
interface Callee { public void foo(Object o); public void foo(String s); public void foo(Integer i); } class CalleeImpl implements Callee { public void foo(Object o) { logger.debug("foo(Object o)"); } public void foo(String s) { logger.debug("foo(\"" + s + "\")"); } public void foo(Integer i) { logger.debug("foo(" + i + ")"); } } Callee callee = new CalleeImpl(); Object i = new Integer(12); Object s = "foobar"; Object o = new Object(); callee.foo(i); callee.foo(s); callee.foo(o);
Setelah dilaksanakan, kod ini secara tidak dijangka mencetak "foo(Object o)" tiga kali, dan bukannya memilih yang berbeza pelaksanaan berdasarkan jenis parameter sebenar.
Punca Punca
Dalam Java, permintaan kaedah dihantar secara dinamik untuk objek yang kaedah dipanggil, tetapi bukan untuk parameter jenis. Spesifikasi Bahasa Java secara eksplisit menyatakan bahawa "jenis masa kompilasi argumen" menentukan tandatangan kaedah yang dipilih.
Oleh itu, pengisytiharan parameter mengatasi sebarang penukaran jenis berpotensi atau promosi yang berlaku semasa penetapan parameter. Akibatnya, ketiga-tiga panggilan dalam kod yang disediakan diselesaikan kepada kaedah "foo(Object o)" kerana Object ialah jenis yang diisytiharkan bagi ketiga-tiga parameter.
Resolusi
Untuk menyelesaikan isu ini dan mengutamakan jenis parameter sebenar dalam resolusi lebihan, pertimbangkan perkara berikut strategi:
Atas ialah kandungan terperinci Bagaimanakah Kaedah Java Overloading Mengendalikan Jenis Parameter Sebenar lwn. Jenis Diisytiharkan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!