Arrays.sort()方法不接受比较器类型对象的解决方法是使用Comparator接口的实现类来进行排序。
以下是一个示例代码:
import java.util.Arrays;
import java.util.Comparator;
public class SortExample {
public static void main(String[] args) {
Person[] people = { new Person("Alice", 25), new Person("Bob", 20), new Person("Charlie", 30) };
// 使用Comparator接口的实现类来进行排序
Arrays.sort(people, new PersonComparator());
// 打印排序结果
for (Person person : people) {
System.out.println(person.getName() + " - " + person.getAge());
}
}
}
class Person {
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
}
class PersonComparator implements Comparator {
@Override
public int compare(Person person1, Person person2) {
// 按照年龄进行升序排序
return person1.getAge() - person2.getAge();
}
}
在上面的示例中,我们创建了一个Person类来保存人的姓名和年龄。然后,我们创建了一个PersonComparator类来实现Comparator接口,并在compare方法中定义了按照年龄进行升序排序的逻辑。
在main方法中,我们创建了一个Person数组,并使用Arrays.sort()方法进行排序。我们将PersonComparator的实例作为第二个参数传递给Arrays.sort()方法,以告诉它按照我们定义的比较逻辑进行排序。
最后,我们遍历排序后的数组,并打印每个人的姓名和年龄。输出结果应该是按照年龄升序排列的。