標籤:
對於List的排序,第一印象很可能就是用Collections.sort(list); 這個排序是升序排列,一般情況下,是好用的,但是如果碰到這樣一種情況:
List<String> list = new ArrayList<String>();
list.add("192.168.12.1");
list.add("192.168.2.1");
使用Collections.sort(list)後,排序產生的結果是:
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>() {@Overridepublic 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.1
192.168.12.1
JAVA中List的排序