List自定义排序

1、第一种方法,就是list中对象实现Comparable接口,重写compareTo接口, 对排序的字段进行比较。
2、第二种方法,就是在重载Collections.sort方法。

代码示例

package com.xmy.list.sort;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List; /**
* description:list排序
* Created with IDEA
* User:xmy
* Date:2016/10/14
* Time:10:10
*/
public class ListMain { public static void main(String[] args) {
comparePersonOrder();
compareStudentOrder();
compareStudentOrder2();
} /**
* 重载Collections.sort
*/
public static void compareStudentOrder2(){
List<Student> listA = new ArrayList<Student>();
listA.add(new Student("name2", 2));
listA.add(new Student("name1", 1));
listA.add(new Student("name3", 3)); Collections.sort(listA, new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
return o1.getOrder().compareTo(o2.getOrder());
}
}); System.out.println("**********升序**********");
for (Student s : listA) {
System.out.println(s);
}
} /**
* 重载Collections.sort
*/
public static void compareStudentOrder(){
List<Student> listA = new ArrayList<Student>();
listA.add(new Student("name2", 2));
listA.add(new Student("name1", 1));
listA.add(new Student("name3", 3)); System.out.println("**********升序**********");
//升序
Collections.sort(listA, new SortNum());
for (Student s : listA) {
System.out.println(s);
}
//降序
System.out.println("**********降序**********");
Comparator result = Collections.reverseOrder(new SortNum());
Collections.sort(listA,result);
for (Student s : listA) {
System.out.println(s);
} } /**
* Person实现Comparable接口
*/
public static void comparePersonOrder(){
List<Person> listA = new ArrayList<Person>();
listA.add(new Person("name2", 2));
listA.add(new Person("name1", 1));
listA.add(new Person("name3", 3));
//升序
Collections.sort(listA);
System.out.println("**********升序**********");
for (Person p : listA) {
System.out.println(p);
}
//降序
Collections.reverse(listA);
System.out.println("**********降序**********");
for (Person p : listA) {
System.out.println(p);
}
} } /**
* 比较器类
*/
class SortNum implements Comparator{
@Override
public int compare(Object o1, Object o2){
Student s1 = (Student)o1;
Student s2 = (Student)o2;
return s1.getOrder() - s2.getOrder();
}
} class Student { private String name;
private Integer order; public Student(String name, Integer order){
this.name = name;
this.order = order;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public Integer getOrder() {
return order;
} public void setOrder(Integer order) {
this.order = order;
} @Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", order=" + order +
'}';
}
} class Person implements Comparable<Person> { private String name;
private Integer order; @Override
public String toString() {
return "Person{" +
"order=" + order +
", name='" + name + '\'' +
'}';
} public Person(String name, Integer order){
this.name = name;
this.order = order;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public Integer getOrder() {
return order;
} public void setOrder(Integer order) {
this.order = order;
} @Override
public int compareTo(Person arg0) {
return this.getOrder().compareTo(arg0.getOrder());
} }

对复合数据类型的数据的排序

package com.xmy.list.sort;

import java.util.Arrays;
import java.util.Comparator; /**
* description:
* Created with IDEA
* User:xmy
* Date:2016/11/14
* Time:15:55
*/
public class ArrayTest { public static void main(String[] args) {
compareOrder();
} /**
* 排序
*/
public static void compareOrder(){
Point[] points = new Point[4];
for(int i=0;i<4;i++)
points[i]=new Point();
//初始化数据
points[0].order_1=2;points[0].order_2=1;
points[1].order_1=2;points[1].order_2=2;
points[2].order_1=1;points[2].order_2=2;
points[3].order_1=0;points[3].order_2=1;
//自定义排序
Arrays.sort(points, new MyComprator());
//输出排序结果
for(int i=0;i<4;i++)
System.out.println("排序后("+points[i].order_1+","+points[i].order_2+")");
} } class Point{
int order_1;
int order_2;
} /**
* 比较器类
*/
class MyComprator implements Comparator {
public int compare(Object arg0, Object arg1) {
Point point_1 = (Point)arg0;
Point point_2 = (Point)arg1;
//优先按order_1进行升序排列
if(point_1.order_1 != point_2.order_1)
return point_1.order_1 > point_2.order_1 ? 1:-1;
//再按order_2进行升序排列
else
return point_1.order_2 > point_2.order_2 ? 1:-1;
}
}

  

List默认排序

    /**
* 默认list排序方法
*/
public static void sortList(){
List<String> list = new ArrayList();
list.add("赵");
list.add("钱");
list.add("孙");
list.add("李");
list.add("周"); //注意:是根据的汉字的拼音的字母排序的,而不是根据汉字一般的排序方法
System.out.println("**********升序**********");
Collections.sort(list,Collator.getInstance(Locale.CHINA));
for(String temp : list){
System.out.println(temp);
}
System.out.println("**********降序**********");
Collections.reverse(list);
for(String temp : list){
System.out.println(temp);
}
}

数组的排序

1、int[],double[],char[]等基数据类型的数组,Arrays类之只是提供了默认的升序排列

    /**
* 默认数组排序方法
*/
public static void sortArray(){
String[] names = {"赵", "钱", "孙", "李", "周"};
System.out.println("排序前:" + Arrays.toString(names));
//Arrays.sort(names); 排序无效
Arrays.sort(names, Collator.getInstance(Locale.SIMPLIFIED_CHINESE));//升序;
System.out.println(" 升序:" + Arrays.toString(names)); Integer[] ages = {5,7,2,8,1};
System.out.println("排序前:" + Arrays.toString(ages));
Arrays.sort(ages);
System.out.println(" 升序:" + Arrays.toString(ages));
}

  

枚举类型的排序

对于枚举类型的enum1.compareTo(enum2)是按照枚举类型值在定义时的先后顺序比较的,越后面的越大,跟值的字母先后顺序无关。

  

java List的排序的更多相关文章

  1. Java中的排序算法(2)

    Java中的排序算法(2) * 快速排序 * 快速排序使用分治法(Divide and conquer)策略来把一个序列(list)分为两个子序列(sub-lists). * 步骤为: * 1. 从数 ...

  2. Java实现常见排序算法

    常见的排序算法有冒泡排序.选择排序.插入排序.堆排序.归并排序.快速排序.希尔排序.基数排序.计数排序,下面通过Java实现这些排序 1.冒泡排序 package com.buaa; import j ...

  3. Comparable与Comparator,java中的排序与比较

    1:比较和排序的概念 比较:两个实体类之间按>,=,<进行比较. 排序:在集合类中,对集合类中的实体进行排序.排序基于的算法基于实体类提供的比较函数. 基本型别都提供了默认的比较算法,如s ...

  4. Java之List排序出错

    Java之List排序出错 Bound mismatch: The generic method sort(List<T>) of type Collections is not appl ...

  5. Java进阶(三十九)Java集合类的排序,查找,替换操作

    Java进阶(三十九)Java集合类的排序,查找,替换操作 前言 在Java方向校招过程中,经常会遇到将输入转换为数组的情况,而我们通常使用ArrayList来表示动态数组.获取到ArrayList对 ...

  6. java过滤器(过滤器排序)

    java过滤器(过滤器排序) 定义过滤器顺序是很简单的:匹配请求的过滤器将按照它们出现在部署描述符或者编程式配置中的顺序添加到过滤器链中(记住,如果同时再部署描述符或者编程式配置中设置了一些过滤器,那 ...

  7. java实现各种排序算法

    java实现各种排序算法 import java.util.Arrays; public class SomeSort { public static void main(String[] args) ...

  8. ElasticSearch6.0 Java API 使用 排序,分组 ,创建索引,添加索引数据,打分等(一)

    ElasticSearch6.0  Java API  使用     排序,分组 ,创建索引,添加索引数据,打分等 如果此文章对你有帮助,请关注一下哦 1.1 搭建maven 工程  创建web工程 ...

  9. Java实现选择排序

    选择排序思想就是选出最小或最大的数与第一个数交换,然后在剩下的数列中重复完成该动作. package Sort; import java.util.Arrays; public class Selec ...

随机推荐

  1. 微信小程序开发日记——高仿知乎日报(上)

    本人对知乎日报是情有独钟,看我的博客和github就知道了,写了几个不同技术类型的知乎日报APP 要做微信小程序首先要对html,css,js有一定的基础,还有对微信小程序的API也要非常熟悉 我将该 ...

  2. 【干货分享】流程DEMO-补打卡

    流程名: 补打卡申请 业务描述: 当员工在该出勤的工作日出勤但漏打卡时,于一周内填写补打卡申请. 流程相关文件: 流程包.xml 流程说明: 直接导入流程包文件,即可使用本流程 表单:  流程: 图片 ...

  3. iOS之ProtocolBuffer搭建和示例demo

    这次搭建iOS的ProtocolBuffer编译器和把*.proto源文件编译成*.pbobjc.h 和 *.pbobjc.m文件时,碰到不少问题! 搭建pb编译器到时没有什么问题,只是在把*.pro ...

  4. mysql-5.6.34 Installation from Source code

    Took me a while to suffer from the first successful souce code installation of mysql-5.6.34. Just pu ...

  5. 借助 SIMD 数据布局模板和数据预处理提高 SIMD 在动画中的使用效率

    原文链接 简介 为发挥 SIMD1 的最大作用,除了对其进行矢量化处理2外,我们还需作出其他努力.可以尝试为循环添加 #pragma omp simd3,查看编译器是否成功进行矢量化,如果性能有所提升 ...

  6. Fresnel Reflection - 菲涅尔反射

    [Fresnel Reflection - 菲涅尔反射] “菲涅尔”是一个人的名字,因为他发现了一个有关反射的光学现象,这个现象就用这个人的名字命名了.那么,是什么现象呢? 这就是反射/折射与视点角度 ...

  7. json

    #json序列化,只能处理简单的数据类型,如:字典.列表.字符串,类和函数等数据类型过于复杂,不支持序列化import jsondef sayhi(name): print('hello,', nam ...

  8. 如何优雅地使用Sublime Text

    Sublime Text:一款具有代码高亮.语法提示.自动完成且反应快速的编辑器软件,不仅具有华丽的界面,还支持插件扩展机制,用她来写代码,绝对是一种享受.相比于难于上手的Vim,浮肿沉重的Eclip ...

  9. TODO:Github的使用技巧之同步代码

    TODO:Github的使用技巧之同步代码 GitHub 是一个面向开源及私有软件项目的托管平台,因为只支持 Git 作为唯一的版本库格式进行托管,故名 GitHub. GitHub 于 2008 年 ...

  10. ASP.NET MVC5+EF6+EasyUI 后台管理系统(4)-创建项目解决方案

    系列目录 前言 为了符合后面更新后的重构系统,文章于2016-11-1日重写 设计中术语,概念这种东西过于模糊,我们必须学习累积才能认识这些概念模型. 我无法用文章来下详细解析此系统的深层概念,需要大 ...