JAVA中List的排序

對於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

相關文章
相關標籤/搜索