Rumah > Java > javaTutorial > Mengapa Kedalaman Rekursi Bukan Deterministik dalam Java 8 tetapi Deterministik dalam OpenJDK 7?

Mengapa Kedalaman Rekursi Bukan Deterministik dalam Java 8 tetapi Deterministik dalam OpenJDK 7?

Linda Hamilton
Lepaskan: 2024-10-29 06:16:30
asal
585 orang telah melayarinya

Why Is Recursion Depth Non-Deterministic in Java 8 but Deterministic in OpenJDK 7?

Kedalaman Tindanan Bukan Deterministik dalam Java 8

Menentukan kedalaman rekursi maksimum dalam Java boleh menjadi penting untuk memahami penggunaan tindanan dan masalah memori yang berpotensi . Walau bagaimanapun, pada Java 8 Oracle, keputusan yang dilaporkan boleh menjadi bukan penentu, manakala sebaliknya, OpenJDK 7 menghasilkan hasil yang konsisten.

Pengaruh Pengoptimum HotSpot

The Pengoptimum pengkompil HotSpot memberi kesan ketara kepada tingkah laku yang diperhatikan. Apabila kaedah rekursif disusun JIT, pengoptimum boleh mengoptimumkan panggilan kaedah tertentu atau menggabungkan bingkai tindanan bagi berbilang seruan. Pengoptimuman ini membawa kepada keperluan ruang tindanan yang lebih kecil, yang membolehkan rekursi yang lebih mendalam.

Contoh

Pertimbangkan kod berikut:

<code class="java">public static int countDepth() {
    try { return 1+countDepth(); }
    catch(StackOverflowError err) { return 0; }
}</code>
Salin selepas log masuk

Keputusan dengan JIT (dari Oracle's Java 8):

2097
4195
4195
4195
12587
12587
12587
Salin selepas log masuk

Hasil tanpa JIT (dari Oracle's Java 8):

2104
2104
2104
2104
2104
2104
2104
Salin selepas log masuk

Penguatkuasaan Had Tindanan dan ASLR

Faktor lain yang mempengaruhi bukan penentuan ialah cara JVM menguatkuasakan had tindanannya. Jika alamat akhir tindanan memerlukan penjajaran khas (cth., menjajarkan ke sempadan halaman disebabkan oleh sekatan perkakasan), peruntukan tindanan awal mungkin mempunyai kekangan penjajaran yang lebih lemah. Digabungkan dengan Rawak Susun Atur Ruang Alamat (ASLR), ini boleh mengakibatkan jumlah ruang tindanan tersedia yang berubah-ubah, yang membawa kepada kedalaman rekursi bukan deterministik.

Determinisme dalam OpenJDK 7

Berbeza dengan Java 8 Oracle, OpenJDK 7 nampaknya mempunyai penguatkuasaan had tindanan yang lebih konsisten dan tidak menggunakan ASLR secara lalai. Ini menerangkan tingkah laku deterministik yang diperhatikan dalam OpenJDK 7.

Atas ialah kandungan terperinci Mengapa Kedalaman Rekursi Bukan Deterministik dalam Java 8 tetapi Deterministik dalam OpenJDK 7?. 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