Rumah > Java > javaTutorial > Bagaimanakah Saya Boleh Menyelesaikan Amaran 'Akses Reflektif Haram' di Java 9?

Bagaimanakah Saya Boleh Menyelesaikan Amaran 'Akses Reflektif Haram' di Java 9?

Mary-Kate Olsen
Lepaskan: 2024-12-15 03:06:11
asal
630 orang telah melayarinya

How Can I Resolve

Akses Reflektif Haram di Java 9: ​​Peperiksaan Terperinci

Java 9 memperkenalkan konsep akses reflektif haram, yang mencetuskan zahlreichen pada bagaimana untuk menyelesaikannya Soalan tentang mesej ralat ini. Artikel ini akan menyelidiki sifat akses reflektif yang menyalahi undang-undang, keadaan yang mencetuskan makluman dan kemungkinan penyelesaian.

Sistem modul dalam Java 9 memperkenalkan konsep modulariti#enkapsulasi kuat yang menenangkan, yang merupakan kunci untuk memahami akses reflektif yang menyalahi undang-undang. Akses melalui kod dalam modul kepada kod modul lain dan pakej yang kelihatan dikawal dengan ketat. Walau bagaimanapun, untuk облегчить переход на Java 9, enkapsulasi kuat modul boleh dilonggarkan.

Sistem masa jalan boleh menyediakan operasi berikut:

  • Akses statik: Disediakan melalui kod byte yang disusun.
  • Panggilan masa jalan: membenarkan memanggil sistem masa jalannya dengan satu atau lebih pakej satu atau lebih modul sebagai kod dalam semua modul yang tidak dinamakan Terbuka.

Konsep akses haram

Jika API pantulan berjaya dipanggil dalam keadaan berikut, akses pantulan "haram" akan dicetuskan:

  • Biasanya panggilan akan gagal.
  • "Akses tidak sah" didayakan dalam sistem masa jalan.

Mekanisme untuk mencetuskan makluman

Kelonggaran enkapsulasi dalam Java 9 boleh dikawal pada masa penyusunan melalui pilihan permulaan baharu --akses haram. Secara lalai, pilihan ini ditetapkan kepada Benarkan. Dalam mod ini, operasi capaian pertama yang dicerminkan kepada mana-mana pakej sedemikian akan mencetuskan amaran, tetapi tiada amaran lanjut akan dikeluarkan. Amaran ini mengandungi maklumat tentang cara mendayakan amaran selanjutnya.

Pilihan konfigurasi

Pilihan --ilegal-access boleh dikonfigurasikan dalam mod berikut:

  • nyahpepijat: cetak untuk setiap sedemikian akses Mesej dan jejak tindanan.
  • amaran: Cetak mesej untuk setiap akses tersebut.
  • nafikan: Lumpuhkan jenis operasi ini.

Syor Penyahpepijatan dan Pembaikan

  • Jalankan aplikasi dengan --illegal-access=deny untuk mengetahui dan mengelakkan pengisytiharan modul tanpa sebarang ( " opens" pakej dari satu modul ke modul yang lain, termasuk membuka arahan sedemikian, atau secara eksplisit menggunakan argumen VM --add-opens.
  • Gunakan alat jdeps dengan pilihan --jdk-internals untuk mengenal pasti rujukan statik kepada API dalaman JDK dalam kod yang disusun.

Contoh mesej amaran

Mesej amaran yang dikeluarkan apabila operasi capaian reflektif haram dikesan mengikut format berikut:

WARNING: Illegal reflective access by $PERPETRATOR to $VICTIM
Salin selepas log masuk

di mana:

  • $PERPETRATOR: nama yang layak bagi jenis yang mengandungi kod yang mencetuskan operasi pantulan dan sumber kod yang tersedia (iaitu. laluan fail JAR).
  • $VICTIM: Rentetan yang menerangkan ahli yang sedang diakses, termasuk nama yang layak bagi jenis yang disertakan.

Langkah Berjaga-jaga

Untuk mengelakkan amaran sedemikian dan memastikan keselamatan masa hadapan, anda perlu memastikan bahawa modul tidak membuat akses reflektif haram ini.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menyelesaikan Amaran 'Akses Reflektif Haram' di Java 9?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan