Java 的Comparator比较器用法
生活随笔
收集整理的這篇文章主要介紹了
Java 的Comparator比较器用法
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1.定義:Comparator是外部比較器,用于比較來對象與對象之間的,兩個對象進行比較,多用于集合排序,而Comparable可以認為是一個內比較器,根據對象某一屬性進行排序的
2.使用方法
1)定義節點信息
class Node{int x;int y;Node(int x,int y){this.x=x;this.y=y;}@Overridepublic String toString() {return "Node{" +"x=" + x +", y=" + y +'}';} }2)比較器方法
Collections.sort(list, new Comparator<Node>() {/**o1-o2為升序序排列,o2-o1為降序排列,若具體到某一字段,則根據該字段進行排列*/@Overridepublic int compare(Node o1, Node o2) {if (o1.x==o2.x) //若x屬性相等,根據y來升序return o1.y-o2.y;return o1.x-o2.x;//x屬性不相等,根據x來升序排列} });3)完整代碼
import java.util.*;class Node{int x;int y;Node(int x,int y){this.x=x;this.y=y;}@Overridepublic String toString() {return "Node{" +"x=" + x +", y=" + y +'}';} } public class Main {public static void way(int num[],int n){}public static void main(String[] args) {Node node4=new Node(2,2);Node node3=new Node(2,1);Node node1=new Node(1,2);Node node2=new Node(1,1);Node node5=new Node(3,1);Node node6=new Node(3,2);ArrayList<Node> list=new ArrayList<>();list.add(node1);list.add(node2);list.add(node3);list.add(node4);list.add(node5);list.add(node6);Collections.sort(list, new Comparator<Node>() {/**o1-o2為升序序排列,o2-o1為降序排列,若具體到某一字段,則根據該字段進行排列*/@Overridepublic int compare(Node o1, Node o2) {if (o1.x==o2.x) //若x屬性相等,根據y來升序return o1.y-o2.y;return o1.x-o2.x;//x屬性不相等,根據x來升序排列}});for (Node node:list) {System.out.println(node.toString());}} }3.結果如下
總結
以上是生活随笔為你收集整理的Java 的Comparator比较器用法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 求1~n的全排列组合
- 下一篇: 用BlockingQueue实现生产者与