这里是一个类中类去实现条件优先排序的问题

package com.sun;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.List; public class Demo { public Demo() {
// TODO Auto-generated constructor stub
} /**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub int a= 0;
Dob db = new Dob();
Dob db1 = new Dob();
Dob db2 = new Dob();
db.setName("sun");
db.setAge(20);
db.setSex(3); db1.setName("zhi");
db1.setAge(22);
db1.setSex(1); db2.setName("yan");
db2.setAge(21);
db2.setSex(2);
List<Dob> as = new ArrayList<Dob>();
System.out.println("as="+as.size());
as.add(db);
as.add(db1);
as.add(db2); Collections.sort(as, new Comparator<Dob>() {
//比较。如果年龄不同先比较年龄 ,相同就比较性别
public int compare(Dob arg0, Dob arg1) {
int flg = arg0.getAge().compareTo(arg1.getAge());
if(flg==0){
return arg0.getSex().compareTo(arg1.getSex());
}else{
return arg0.getAge().compareTo(arg1.getAge());
} } }); for (Dob p : as) {
System.out.println(p.getName());
System.out.println(p.getAge());
} System.out.println("as="+as.size()); } }
class Dob {
public String name; public Integer age; public Integer sex; public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
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;
} }

  LIst中的MAp

 public void listSort(List<Map<String,Object>> resultList) throws Exception{
// resultList是需要排序的list,其内放的是Map
// 返回的结果集
Collections.sort(resultList,new Comparator<Map<String,Object>>() { public int compare(Map<String, Object> o1,Map<String, Object> o2) { //o1,o2是list中的Map,可以在其内取得值,按其排序,此例为升序,s1和s2是排序字段值
//String FileNumber = GetFileKeyNumber(fileInfo.getKey(),2,2); Map.Entry<String, Object> fileInfo1 = null;
Map.Entry<String, Object> fileInfo2 = null;
Integer s1 = 0;
Integer s2 = 0;
Iterator<Map.Entry<String, Object>> fileMap = o1.entrySet().iterator();
while (fileMap.hasNext()) {
fileInfo1 = fileMap.next();
s1 = Integer.parseInt(GetFileKeyNumber(fileInfo1.getValue().toString(),2,2));
} Iterator<Map.Entry<String, Object>> fileMap2 = o2.entrySet().iterator();
while (fileMap2.hasNext()) {
fileInfo2 = fileMap2.next();
s2 = Integer.parseInt(GetFileKeyNumber(fileInfo2.getValue().toString(),2,2));
} if(s1>s2) {
return 1;
}else {
return -1;
}
}
}); }

  

Java中List的排序和List的MAp的更多相关文章

  1. Java中List,ArrayList、Vector,map,HashTable,HashMap区别用法

    Java中List,ArrayList.Vector,map,HashTable,HashMap区别用法 标签: vectorhashmaplistjavaiteratorinteger ArrayL ...

  2. Java中常见的排序方法

    本博主要介绍Java中几种常见的排序算法: /* 排序方法的演示1)插入排序(直接插入排序.希尔排序)2)交换排序(冒泡排序.快速排序)3)选择排序(直接选择排序.堆排序)4)归并排序5)分配排序(基 ...

  3. java中字符串的排序(1)

    按照前段时间在快速.冒泡等排序的评论中提到是否可以进行字符串的排序,由于最近有考试,时间比较紧,所以今天才实现此功能.此功能是针对一串字符川进行的实现,运行后的结果如下所示: 具体的程序相对较为简单, ...

  4. java中的选择排序之降序排列

    import java.util.Arrays;//必须加载 class Demo{ public static void main(String []args){ int[] arr={3,54,4 ...

  5. Java中 Collection 、 List 、 Set 、 Map详解

    一.容器( Collection ) 接口    容器( Collection )是最基本的集合接口,一个容器( Collection )保存一组对象( Object ),即对象是容器的元素( Ele ...

  6. Java中Array、List、Set、Map

    一.Java中数组 数组用来存放固定数量的同类元素,声明方法: T[] ref,T ref[],如int[] intAry; int intAry[].推荐用T[]的方式,后一种方式为兼容C++习惯写 ...

  7. JAVA中利用反射机制进行对象和Map相互转换的方法

    JAVA的反射机制主要作用是用来访问对象的属性.方法等等.所以,JAVA中对象和Map相互转换可以利用JAVA的反射机制来实现.例子如下: 一.对象转Map的方法 public static Map& ...

  8. java中Collections.sort排序详解

    Comparator是个接口,可重写compare()及equals()这两个方法,用于比价功能:如果是null的话,就是使用元素的默认顺序,如a,b,c,d,e,f,g,就是a,b,c,d,e,f, ...

  9. java中List的排序功能的实现

    今天在工作的时候,遇到了List排序的问题,所以总结了一下,与大家分享.Collections.sort排序的时候,用到了Comparator接口下面的compare()方法.下面的小例子中,还用到了 ...

随机推荐

  1. debian 6软件更新源列表

    deb http://ftp.debian.org/debian/ squeeze main non-free contribdeb http://ftp.debian.org/debian/ squ ...

  2. 【jQuery】jquery中 使用$('#parentUid').attr(parentUid);报错jquery-1.11.3.min.js:5 Uncaught TypeError: Cannot read property 'nodeType' of undefined

    jquery中 使用$('#parentUid').attr(parentUid);报错jquery-1.11.3.min.js:5 Uncaught TypeError: Cannot read p ...

  3. 直接拿来用!最火的Android开源项目(一)

    GitHub在中国的火爆程度无需多言,越来越多的开源项目迁移到GitHub平台上.更何况,基于不要重复造轮子的原则,了解当下比较流行的Android与iOS开源项目很是必要.利用这些项目,有时能够让你 ...

  4. Swift,初始化

    1.class中的值是没办法不赋值,不然会报错,那么就有个init的方法初始化(这个方法使得实例时必须加上参数) class test{ var a:String var b:Int init(a:S ...

  5. BigDecimal的精度舍入模式详解

    BigDecimal舍入模式介绍: 舍入模式在java.math.RoundingMode 里面: RoundingMode.CEILING :向正无限大方向舍入的舍入模式.如果结果为正,则舍入行为类 ...

  6. [转载]DIY树莓派之随身工具箱

    摆弄树莓派有一年多了,在这里把经验分享给大家,少走弯路. 先放图两张. 搭建目的: wifi信号中转站\网站服务器\IC卡渗透测试\中间人\otr… 基于树莓派3 系统为Kali Linux 2017 ...

  7. ubuntu16.04 登录密码破解方法

    1:开机按Shift键,出现如下界面.(手速要快,Shift键要按时间久一点) 选择第二项 2:按回车键进入如下界面,然后选中有recovery mode的选项(第三项) 3:按e进入如下界面,并找到 ...

  8. Windows数据备份软件Deltacopy-数据备份与还原

    官方网站:http://www.aboutmyip.com/AboutMyXApp/DeltaCopy.jsp System Requirements XP, 2000, 2003, 2008, Vi ...

  9. FL2440 Linux-3.0内核触摸屏的支持

    ---------------------------------------------------------------------------------------------------- ...

  10. OS中处理机调度模型和调度算法

    OS中处理机调度模型和调度算法 调度层次 1.1. 高级调度(长程调度,作业调度) 功能:依据某种算法.把在外存队列上处于后备队列的那些作业调入内存.以作业为操做对象. 作业:比程序更为广泛的概念,不 ...