要实现ArrayList按优先级排序,可以根据优先级编写一个自定义的Comparator来进行排序。以下是一个示例代码:
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
class Task {
private int priority;
private String description;
public Task(int priority, String description) {
this.priority = priority;
this.description = description;
}
public int getPriority() {
return priority;
}
public String getDescription() {
return description;
}
}
public class Main {
public static void main(String[] args) {
List tasks = new ArrayList<>();
tasks.add(new Task(3, "Task 1"));
tasks.add(new Task(1, "Task 2"));
tasks.add(new Task(2, "Task 3"));
// 使用自定义的Comparator对ArrayList进行排序
Collections.sort(tasks, new Comparator() {
@Override
public int compare(Task task1, Task task2) {
return Integer.compare(task1.getPriority(), task2.getPriority());
}
});
// 输出排序后的结果
for (Task task : tasks) {
System.out.println(task.getDescription());
}
}
}
运行以上代码,输出结果为:
Task 2
Task 3
Task 1
在这个示例中,Task类表示一个任务,包含优先级和描述两个属性。通过实现Comparator接口,我们定义了一个按照优先级升序排序的比较器。然后使用Collections.sort方法对ArrayList进行排序。最后,遍历排序后的ArrayList,输出排序结果。