• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
bella-java-blog
博客园    首页    新随笔    联系   管理    订阅  订阅

java中重写Comparator对两个list集合排序

public class test{  

  public static void main(String[] args) {  

  List<LeaveRequest>  LvRequestList=new List<LeaveRequest>();

  List<OtRequest> otRequestList=new List<OtRequest>();

  List   allList=new List();

  allList.addAll( LvRequestList);
  allList.addAll(otRequestList);

  RequestComparator comparator=new RequestComparator();
  Collections.sort(list,comparator);

  //这样就对两个装有不同类型的list按时间进行了排序

 

  }

}

 

//Comparator

 

package com.hkairport.oaa.service.report;

import java.util.Comparator;
import java.util.Date;

import com.hkairport.oaa.model.application.LeaveRequest;
import com.hkairport.oaa.model.application.OtRequest;

public class RequestComparator implements Comparator {

public int compare(Object o1, Object o2) {
  return getDate(o1).compareTo(getDate(o2));
  }

  public Date getDate(Object o) {
  Date date = null;
  if (o instanceof OtRequest) {
  date = ((OtRequest) o).getOtDateFrom();
  }
  if (o instanceof LeaveRequest) {
  date = ((LeaveRequest) o).getLeaveDateFrom();
  }
  return date;

  }
}

posted @ 2014-07-23 15:09  bella-java-blog  阅读(973)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3