Rumah >Java >javaTutorial >Mengapakah objek Java yang boleh dicapai dimuktamadkan dalam Java 8, walaupun amalan terbaik tidak menggalakkan `finalize()`?

Mengapakah objek Java yang boleh dicapai dimuktamadkan dalam Java 8, walaupun amalan terbaik tidak menggalakkan `finalize()`?

Linda Hamilton
Linda Hamiltonasal
2024-12-14 05:44:11847semak imbas

Why are reachable Java objects finalized in Java 8, despite best practices discouraging `finalize()`?

JVM Penyelesaian Objek Boleh Dicapai di Java 8: Satu Penerokaan

Walaupun mematuhi amalan terbaik yang tidak menggalakkan penggunaan finalize(), a naik taraf baru-baru ini daripada Java 7 kepada Java 8 telah membawa kepada isu yang tidak dijangka. Dalam senario ini, objek yang masih boleh dicapai dengan kuat oleh timbunan utas semasa sedang tertakluk kepada pemuktamadan dalam masa jalan Java 8.

Memahami Kod dan Pengecualian

The kod yang dimaksudkan melibatkan perpustakaan MIME tersuai, di mana kelas MIMEBodyPart memanjangkan HTTPMessage. HTTPMessage melaksanakan kaedah finalize() yang cuba menutup strim input yang berkaitan, membawa kepada pengecualian apabila strim sudah ditutup semasa operasi writePart() aktif.

Menyiasat Punca

Terkejut dengan pemuktamadan yang tidak dijangka, pembangun menyelidiki lebih mendalam tentang kod dan gelagat JVM. Telah didapati bahawa objek MIMEBodyPart sememangnya boleh dicapai daripada susunan urutan semasa, dan oleh itu, tidak sepatutnya dimuktamadkan.

Menghipotesiskan Kemungkinan Tidak Dapat Dicapai

Walaupun kebolehcapaian jelas objek, ia telah berteori bahawa Mesin Maya Java (JVM) masih boleh menganggapnya sebagai tidak boleh dicapai jika ia tidak dirujuk secara eksplisit dalam kod berikutnya. Konsep "keupayaan unreach" ini juga meluas kepada panggilan kaedah aktif pada tindanan.

Contoh Menunjukkan Ketidakbolehcapaian

Untuk menggambarkan tingkah laku ini, contoh kod yang dipermudahkan telah dibentangkan:

class FinalizeThis {
    @Override
    protected void finalize() {
        System.out.println("finalized!");
    }

    void loop() {
        System.out.println("loop() called");
        for (int i = 0; i < 1,000,000,000; i++) {
            if (i % 1,000,000 == 0)
                System.gc();
        }
        System.out.println("loop() returns");
    }

    public static void main(String[] args) {
        new FinalizeThis().loop();
    }
}

Dalam contoh ini, kaedah gelung() termasuk gelung besar-besaran yang mencetuskan pengumpulan sampah secara berkala. Walaupun kaedah gelung secara aktif memanggil kaedah contoh bagi objek FinalizeThis, JVM memuktamadkan dan sampah mengumpul objek tersebut disebabkan ketidakupayaan dicapainya yang jelas.

Menggunakan Hipotesis pada Senario Asal

Adalah sangkaan bahawa situasi yang sama mungkin berlaku dalam kes MIMEBodyPart objek. Jika ia disimpan dalam pembolehubah tempatan tanpa sebarang rujukan berikutnya, ia boleh menjadi tidak dapat dicapai dan terdedah kepada pemuktamadkan.

Kemas kini dan Pemerhatian Tambahan

Melalui ujian dan analisis lanjut, ternyata bahawa pengkompil JIT memainkan peranan dalam tingkah laku ini. Dengan memaksa kaedah untuk disusun JIT sebelum pelaksanaan (pilihan-Xcomp), isu pemuktamadan pramatang muncul semula. Ini menunjukkan bahawa kekurangan awal pemuktamadan dalam contoh yang dipermudahkan adalah disebabkan oleh tafsiran dan bukannya kompilasi, yang melakukan analisis kebolehcapaian yang lebih agresif.

Kesimpulan

Walaupun perincian isu mungkin berbeza-beza bergantung pada struktur kod dan persekitaran pelaksanaan yang tepat, konsep asas potensi pemuktamadan walaupun untuk objek yang boleh dicapai disebabkan oleh ketidakupayaan yang dirasakan perlu diberi perhatian. Ia menekankan kepentingan memahami kebolehcapaian objek dan kemungkinan akibat daripada panggilan pemuktamadan pada objek aktif.

Atas ialah kandungan terperinci Mengapakah objek Java yang boleh dicapai dimuktamadkan dalam Java 8, walaupun amalan terbaik tidak menggalakkan `finalize()`?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn