List排序


在Web開發中要排序都是基於sql的,不管事jdbc還是hibenrate、mybatis這些orm框架。。那麼,如果單純的拿到了一個結果集,我們在集合裏怎麼排序呢?

這裏給出一個demo。。



首先看一個bean:

package com.test;

public class User {

	private String userName;
	
	private Integer age;
	
	private Integer sex;

	public String getUserName() {
		return userName;
	}

	public void setUserName(String userName) {
		this.userName = userName;
	}

	public Integer getAge() {
		return age;
	}

	public void setAge(Integer age) {
		this.age = age;
	}

	public Integer getSex() {
		return sex;
	}

	public void setSex(Integer sex) {
		this.sex = sex;
	}
	
	
}


再看具體的排序過程:

package com.test;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
/**
 * 
 * @author xiatianlong
 *
 * @date 2016年8月10日 下午4:15:32
 */
public class CollectionSort {

	
	public static void main(String[] args) {
		
		
		List<User> userList = new ArrayList<User>();
		
		// 初始化數據
		for (int i = 0; i < 5; i++){
			User user = new User();	
			if (i%2 == 0){
				user.setUserName("張" + i + "開");
				user.setSex(0);
			}else{
				user.setSex(1);
				user.setUserName("李" + i + "山");
			}
			user.setAge(20 + i);
			userList.add(user);
		}
		
		System.out.println("排序前:");
		for (User user : userList) {
			System.out.println(user.getUserName() + "  " + user.getSex() + "  " + user.getAge());
		}
		
		// 根據性別進行排序
		Collections.sort(userList, new Comparator<User>() {   
            public int compare(User user1,User user2) {  
            return user1.getUserName().compareTo(user2.getUserName());   
            }   
       }); 
		
		System.out.println("------------------");
		
		System.out.println("根據性別排序後:");
		for (User user : userList) {
			System.out.println(user.getUserName() + "  " + user.getSex() + "  " + user.getAge());
		}
		
	}
}

看打印的結果:







發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章