Rumah >Java >javaTutorial >## Bolehkah Anda Mengemas kini Keutamaan dalam Java PriorityQueue Tanpa Mengalih Keluar dan Memasukkan Semula?
Mengemas kini Keutamaan dalam Java PriorityQueues
Apabila menggunakan PriorityQueue dengan Comparator untuk pesanan objek, perubahan seterusnya kepada pembolehubah kelas objek (selepas keutamaan mana yang dikira) memberikan cabaran.
Secara tradisinya, penyelesaian mudah melibatkan pengalihan keluar objek, mengemas kini nilainya dan memasukkannya semula, mencetuskan pembanding barisan keutamaan. Walau bagaimanapun, adakah terdapat alternatif yang lebih cekap untuk mencipta kelas pembalut di sekitar PriorityQueue?
Jawapan
Malangnya, mengalih keluar dan memasukkan semula kekal sebagai pendekatan yang paling berkesan. PriorityQueues sememangnya memasukkan elemen baharu ke dalam kedudukan yang sesuai selepas dimasukkan, mengoptimumkan prestasi baris gilir. Mencari elemen keutamaan tertinggi semasa operasi dequeue akan memberi kesan ketara kepada prestasi.
TreeMaps berkongsi pengehadan ini, bersama-sama dengan HashMaps (yang gagal jika kod cincang elemen berubah).
Mencipta kelas pembalut mungkin melibatkan memindahkan kod perbandingan dari enqueue ke dequeue, menghapuskan keperluan untuk menyusun semasa enqueue. Walau bagaimanapun, pendekatan ini menjejaskan prestasi dan memerlukan penyegerakan apabila kemas kini keutamaan. Memandangkan penyegerakan diperlukan sama ada cara, dequeue dan re-enqueue menyediakan penyelesaian yang lebih mudah dan lebih berprestasi.
Atas ialah kandungan terperinci ## Bolehkah Anda Mengemas kini Keutamaan dalam Java PriorityQueue Tanpa Mengalih Keluar dan Memasukkan Semula?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!