1:list<Object[]>的排序

 public static void main(String[] args) {

// TODO Auto-generated method stub

        Object[] o1 = new Object[4];

        o1[0] = "5";

        o1[1] = "o1";

        o1[2] = "o11";

        o1[3] = "o111";

        Object[] o2 = new Object[4];

        o2[0] = "3";

        o2[1] = "o2";

        o2[2] = "o22";

        o2[3] = "o222";

        List<Object[]> list = new ArrayList<>();

        list.add(o1);

        list.add(o2);

//很明显我们先添加的对象o1,所以先打印o1,

        for (inti = 0; i < list.size(); i++) {

            for (intj = 0; j < 4; j++) {

                System.out.print(list.get(i)[j] + "  ");

            }

        }

        System.out.println("\n排序后-------");

        sortList(list);

//排序后:

        for (inti = 0; i < list.size(); i++) {

            for (intj = 0; j < 4; j++) {

                System.out.print(list.get(i)[j] + "  ");

            }

        }
}
 
写一个方法

public staticvoid sortList(List<Object[]> ls) {

        Collections.sort(ls, new Comparator<Object[]>() {

            @Override

            public int compare(Object[] o1, Object[] o2) {

                if (Integer.valueOf(o1[0].toString()) > Integer.valueOf(o2[0].toString())) {

                    return 1;

                }

                return -1;

            }

        });

    }
 
 
 

2:list<Student>排序,主要是正对汉族的排序,按照拼音排序.

首先写一个Student类

    package com.model;

    public class Student {

        public Stringname;

        publicintage;

        public Student(Stringname, intage) {

            this.name = name;

            this.age = age;

        }

        public void setName(String name) {

            this.name = name;

        }

        public String getName() {

            returnname;

        }

        public void setAge(int age) {

            this.age = age;

        }

        public int getAge() {

            returnage;

        }

    }
然后在main方法中调用,(这里写的是一个java文件)
 Student stu1 = new Student("张三", 23);

        Student stu2 = new Student("李四", 25);

        List<Student> listStudent = new ArrayList<>();

        listStudent.add(stu1);

        listStudent.add(stu2);

        System.out.println();

        for (int i = 0; i < listStudent.size(); i++) {

            System.out.print(listStudent.get(i).getName() + "---" + listStudent.get(i).getAge());

        }

        System.out.println("\n排序后");

        sortListStudent(listStudent);

        for (int i = 0; i < listStudent.size(); i++) {

            System.out.print(listStudent.get(i).getName() + "---" + listStudent.get(i).getAge());

        }

写一个排序方法

 public staticvoid sortListStudent(List<Student> ls) {

        Collections.sort(ls, new Comparator<Student>() {

            @Override

            public int compare(Student o1, Student o2) {

                String s1 = o1.getName();

                String s2 = o2.getName();

                if (s1.compareTo(s2) > 0) {

                    return -1;

                }

                return 1;

            }

        });

    }
结果图:

 

3:list<Map<String,String>>排序问题:

public class MapListSort {
public static void main(String[] args) {
// TODO Auto-generated method stub
List<Map<String, String>> listMap = new ArrayList<>();
Map<String, String> map1 = new HashMap<String, String>();
map1.put("map001", "001");
map1.put("map003", "map003");
map1.put("map002", "map002");
Map<String, String> map2 = new HashMap<String, String>();
map2.put("map001", "101");
map2.put("map003", "map303");
map2.put("map002", "map202");
//先添加的map2,但是map2中map001的值大于map1中的map001的值。
listMap.add(map2);
listMap.add(map1); for (int i = 0; i < listMap.size(); i++) {
System.out.print(listMap.get(i).get("map001") + "," + listMap.get(i).get("map002") + "," + listMap.get(i).get("map003") + "\n");
} mapSorts(listMap); System.out.println("\n排序后:");
for (int i = 0; i < listMap.size(); i++) {
System.out.print(listMap.get(i).get("map001") + "," + listMap.get(i).get("map002") + "," + listMap.get(i).get("map003") + "\n");
}
} public static void mapSorts(List<Map<String, String>> map) {
Collections.sort(map, new Comparator<Map<String, String>>() { @Override
public int compare(Map<String, String> o1, Map<String, String> o2) {
// TODO Auto-generated method stub
if (o1.get("map001").compareTo(o2.get("map001")) > 0) {
return 1;
}
return -1;
}
});
}
}

 
 
 
 

Java中list<Object[]>、list<Student>、list<Map<String,String>>排序的更多相关文章

  1. Java中的容器类(List,Set,Map,Queue)

    Java中的容器类(List,Set,Map,Queue) 一.基本概念 Java容器类类库的用途是“保存对象”,并将其划分为两个不同的概念: 1)Collection.一个独立元素的序列,这些元素都 ...

  2. Java学习笔记二十四:Java中的Object类

    Java中的Object类 一:什么是Object类: Object类是所有类的父类,相当于所有类的老祖宗,如果一个类没有使用extends关键字明确标识继承另外一个类,那么这个类默认继承Object ...

  3. Java中的集合(十二) 实现Map接口的WeakHashMap

    Java中的集合(十二) 实现Map接口的WeakHashMap 一.WeakHashMap简介 WeakHashMap和HashMap一样,WeakHashMap也是一个哈希表,存储的也是键值对(k ...

  4. 多用多学之Java中的Set,List,Map

            很长时间以来一直代码中用的比较多的数据列表主要是List,而且都是ArrayList,感觉有这个玩意就够了.ArrayList是用于实现动态数组的包装工具类,这样写代码的时候就可以拉进 ...

  5. java中key值可以重复的map:IdentityHashMap

    在Java中,有一种key值可以重复的map,就是IdentityHashMap.在IdentityHashMap中,判断两个键值k1和 k2相等的条件是 k1 == k2 .在正常的Map 实现(如 ...

  6. Java中的list与Set、Map区别及适用场景

    Collection接口是集合类的根接口,Java中没有提供这个接口的直接的实现类,但是却让其被继承产生了两个接口,就是Set和List.Set中不能包含重复的元素.List是一个有序的集合,可以包含 ...

  7. Java基础学习总结(29)——浅谈Java中的Set、List、Map的区别

    就学习经验,浅谈Java中的Set,List,Map的区别,对JAVA的集合的理解是想对于数组: 数组是大小固定的,并且同一个数组只能存放类型一样的数据(基本类型/引用类型),JAVA集合可以存储和操 ...

  8. Java基础(43):Java中的Object类与其方法(转)

    Object类 java.lang.Object java.lang包在使用的时候无需显示导入,编译时由编译器自动导入. Object类是类层次结构的根,Java中所有的类从根本上都继承自这个类. O ...

  9. Java中list<Object>集合去重实例

    一:Java中list去重的方法很多,下面说一下其中一种方法:把list里的对象遍历一遍,用list.contain(),如果不存在就放入到另外一个list集合中: 二:实例 这里需要注意的是:使用c ...

随机推荐

  1. Redis 高可用集群

    Redis 高可用集群 Redis 的集群主从模型是一种高可用的集群架构.本章主要内容有:高可用集群的搭建,Jedis连接集群,新增集群节点,删除集群节点,其他配置补充说明. 高可用集群搭建 集群(c ...

  2. django事务处理

    #导包 from django.db import transaction try: #django默认是自动提交到数据库,此处设置不让其自动提交 transaction.set_autocommit ...

  3. python并发编程之多进程二

    一,multiprocessing模块介绍 python中的多线程无法利用多核优势,如果想要充分地使用多核CPU的资源(os.cpu_count()查看),在python中大部分情况需要使用多进程.P ...

  4. Web应用与应用层协议

    Web应用与应用层协议 本篇博文中的主要参考文献是<计算机网络高级教程>,分别是吴功宜老先生和吴英教授合著.这部教程是我研究生老师所推荐的网络必读科目,由于该教程讲解的基础知识详细,但内容 ...

  5. javascript设计模式——单例模式

    前面的话 单例模式是指保证一个类仅有一个实例,并提供一个访问它的全局访问点. 单例模式是一种常用的模式,有一些对象往往只需要一个,比如线程池.全局缓存.浏览器中的window对象等.在javaScri ...

  6. 基于TCP协议的socket编程

    什么是socket Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口.在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面, ...

  7. memcached 安装以及在php中使用

    最近做的一个项目需要不断对数据库内容进行读取和刷新,所以数据库压力很大,用户数目多的时候响应速度也严重受影响. 于是准备将一部分常用数据通过缓存在服务器内存中,减少对数据库的操作来缓解压力(memca ...

  8. CSS的常见问题

    1.css的编码风格 多行式:可读性越强,但是CSS文件的行数过多,影响开发速度,增大CSS文件的大小 一行式:可读性稍差,有效减少CSS文件的行数,有利于提高开发速度,减小CSS文件的大小 2.id ...

  9. .Net Core实现将文件上传到七牛云存储

    功能:将图片上传到七牛云存储 准备工作 注册七牛账号,提交实名认证(基本上1天内内审核通过) 登录七牛后台->对象存储->新建空间 (基本概念:https://developer.qini ...

  10. AspNet Core Api Restful +Swagger 实现微服务之旅 (三)

    (1)  访问Rest ful接口时 Token验证  返回数据格式封装 (一)访问时Token验证  返回数据格式封装 1.1访问Api接口 方法 实现         1.1.1 创建访问Rest ...