Rumah >Java >javaTutorial >Bagaimana untuk Menulis Fungsi Pembanding Tersuai di Java?
Di Java, antara muka Comparator menyediakan cara untuk membandingkan dua objek untuk menentukan susunannya. Ini amat berguna apabila anda ingin mengisih koleksi seperti senarai atau tatasusunan dalam susunan tersuai.
Peribadi Pembanding diperlukan apabila susunan semula jadi objek (seperti yang ditakrifkan oleh pelaksanaan Sebandingnya) tidak memenuhi keperluan anda. Contohnya, mengisih senarai objek Pekerja mengikut gaji, nama atau umur mungkin memerlukan pembanding yang berbeza.
Mari kita ikuti proses mencipta Pembanding tersuai.
Pertimbangkan kelas Pekerja dengan medan nama , umur dan gaji. Kami ingin mengisih senarai Pekerja objek mengikut gaji dalam tertib menaik.
import java.util.Comparator; class Employee { private String name; private int age; private double salary; // Constructor, getters, and setters public Employee(String name, int age, double salary) { this.name = name; this.age = age; this.salary = salary; } public double getSalary() { return salary; } @Override public String toString() { return "Employee{" + "name='" + name + ''' + ", age=" + age + ", salary=" + salary + '}'; } } class SalaryComparator implements Comparator<Employee> { @Override public int compare(Employee e1, Employee e2) { return Double.compare(e1.getSalary(), e2.getSalary()); } }
Dalam contoh ini, kelas SalaryComparator melaksanakan antara muka Comparator dan mengatasi kaedah bandingkan untuk membandingkan pekerja mengikut gaji mereka.
Sekarang, mari buat senarai pekerja dan susunkannya menggunakan Pembanding tersuai kami.
import java.util.ArrayList; import java.util.Collections; import java.util.List; public class Main { public static void main(String[] args) { List<Employee> employees = new ArrayList<>(); employees.add(new Employee("John", 28, 50000)); employees.add(new Employee("Anna", 32, 75000)); employees.add(new Employee("Mike", 25, 45000)); System.out.println("Before Sorting:"); employees.forEach(System.out::println); // Sort employees by salary Collections.sort(employees, new SalaryComparator()); System.out.println(" After Sorting by Salary:"); employees.forEach(System.out::println); } }
Menjalankan kod di atas akan menghasilkan output berikut:
Before Sorting: Employee{name='John', age=28, salary=50000.0} Employee{name='Anna', age=32, salary=75000.0} Employee{name='Mike', age=25, salary=45000.0} After Sorting by Salary: Employee{name='Mike', age=25, salary=45000.0} Employee{name='John', age=28, salary=50000.0} Employee{name='Anna', age=32, salary=75000.0}
Senarai pekerja kini disusun mengikut gaji mereka dalam tertib menaik, terima kasih kepada adat Pembanding.
Kadangkala, anda mungkin memerlukan logik perbandingan yang lebih kompleks atau ingin mengisih mengikut berbilang medan.
Mari ubah suai Komparator kami untuk mengisih mengikut gaji dan kemudian dengan nama sekiranya seri.
class SalaryThenNameComparator implements Comparator<Employee> { @Override public int compare(Employee e1, Employee e2) { int salaryCompare = Double.compare(e1.getSalary(), e2.getSalary()); if (salaryCompare == 0) { return e1.getName().compareTo(e2.getName()); } return salaryCompare; } }
Menggunakan SalaryThenNameComparator , anda kini boleh mengisih pekerja mengikut gaji dan nama:
Collections.sort(employees, new SalaryThenNameComparator());
Menulis fungsi Pembanding tersuai dalam Java membolehkan anda menyesuaikan gelagat pengisihan koleksi untuk memenuhi keperluan khusus. Sama ada anda memerlukan perbandingan mudah dengan satu medan atau pengisihan kompleks mengikut berbilang kriteria, Comparator menyediakan penyelesaian yang fleksibel dan berkuasa.
Jika anda mempunyai sebarang pertanyaan atau memerlukan penjelasan lanjut, sila tinggalkan komen di bawah!
Baca siaran lebih lanjut di : Bagaimana Menulis Fungsi Pembanding Tersuai dalam Java?
Atas ialah kandungan terperinci Bagaimana untuk Menulis Fungsi Pembanding Tersuai di Java?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!