Java's Mystifying NullPointerException dengan Elusive StackTrace
Semasa menyelesaikan masalah kod Java, anda mungkin menghadapi masalah yang membingungkan di mana NullPointerException ditangkap tetapi StackTracenya kekal sukar difahami, hanya memaparkan nama pengecualian kosong. Tingkah laku pelik ini telah menimbulkan kebimbangan dalam kalangan pembangun.
Menyelesaikan Enigma
Setelah penyiasatan lanjut, didapati fenomena yang membingungkan ini mungkin disebabkan oleh pengoptimuman yang dilakukan oleh HotSpot JVM (daripada Oracle). Untuk memintas isu ini dan mendapatkan maklumat surih tindanan yang berharga, gunakan hujah JVM berikut:
-XX:-OmitStackTraceInFastThrow
Pengoptimuman Di Sebalik Tabir
JVM HotSpot memanfaatkan pengoptimuman untuk meningkatkan prestasi. Apabila pengecualian, terutamanya NullPointerException, kerap berlaku, surih tindanan penuh ditangkap pada mulanya dan disimpan dalam ingatan JVM. Walau bagaimanapun, kejadian seterusnya bagi pengecualian yang sama mencetuskan pengoptimuman prestasi di mana surih tindanan ditinggalkan. Pendekatan dwi ini mengoptimumkan prestasi dan menghalang fail log daripada menjadi bersepah dengan surih tindanan berulang.
Pelaksanaan JVM
Bagi mereka yang ingin tahu tentang pelaksanaan, semak sumber JVM HotSpot kod mendedahkan kewujudan pembolehubah global bernama OmitStackTraceInFastThrow. Mulai 2019, pembolehubah ini boleh ditemui dalam fail graphKit.cpp, mengatur gelagat yang dinyatakan di atas.
Kesimpulan
Dengan memanfaatkan hujah -XX:-OmitStackTraceInFastThrow, pembangun boleh mendapatkan semula keupayaan untuk memeriksa StackTrace penuh semasa pengendalian NullPointerException, memudahkan penyahpepijatan dan penyelesaian masalah yang lebih tepat.
Atas ialah kandungan terperinci Mengapa Java NullPointerException Saya Mempunyai StackTrace yang Hilang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!