對於List的排序,第一印象極可能就是用Collections.sort(list); 這個排序是升序排列,通常狀況下,是好用的,可是若是碰到這樣一種狀況:java
List<String> list = new ArrayList<String>();ide
list.add("192.168.12.1");
list.add("192.168.2.1");this
使用Collections.sort(list)後,排序產生的結果是:blog
192.168.12.1
192.168.2.1排序
這樣可能不符合咱們的預期,這上面的兩個字符串是兩個內網IP地址,通常狀況下,咱們會認爲192.168.2.1是要先於192.168.12.1的,因此,在這種狀況下,咱們須要實現Comparator接口:接口
package com.demo; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; public class Test12 { public void sort(){ List<String> list = new ArrayList<String>(); list.add("192.168.12.2"); list.add("192.168.2.1"); Collections.sort(list, new Comparator<String>() { @Override public int compare(String s1, String s2) { String[] ss1 = s1.split("\\."); String[] ss2 = s2.split("\\."); for (int i = 0; i < ss1.length; i++) { if(Integer.valueOf(ss1[i])<Integer.valueOf(ss2[i])){ return -1; }else if(Integer.valueOf(ss1[i])>Integer.valueOf(ss2[i])){ return 1; } } return 0; } }); this.outputList(list); } private void outputList(List<String> list){ for (String i : list) { System.out.println(i); } } public static void main(String[] args) { Test12 t = new Test12(); t.sort(); } }
此時輸出的結果就爲:字符串
192.168.2.1it
192.168.12.1
io