在平时开发的过程中,经常会遇到需要对数组、集合中元素按规则进行排序,本文记录在开发过程中可能遇到的情况以及相关的完整代码示例。

知识点

  • Comparable<T>接口

    实现了该接口的对象,必须重写compareTo方法,对象实现了该接口,则该对象具有排序功能,比如String、Integer等。
  • Comparator<T>接口

    要实现自定义排序器的时候,需要实现该接口。当某个类不具备排序功能或者已有的排序功能不足以支撑你需求的时候,就是自定义排序器登场的时候了。比如String内置的排序实现按字符顺序排序,那我想按字符串长度排序咋办呢?这时就可以自定义实现Comparator的对象了。
  • 数组(比如String[])排序使用Arrays.sort
  • 集合(比如List<T>)排序使用Collections.sort

实例

1. 默认String排序示例

1.1 数组排序用法

String[] strArr = new String[]{"zhangsan","lisi","wangwu"};
//数组默认按字符升序排序
Arrays.sort(strArr);
System.out.println("默认按字母升序排序:");
for (String str:strArr) {
System.out.println(str);
}

1.2 集合排序用法

List<String> strList = new ArrayList<>();
strList.add("zhangsan");
strList.add("lisi");
strList.add("wangwu");
//集合默认按字符升序排序
Collections.sort(strList);
System.out.println("默认按字母升序排序:");
for (String str:strList) {
System.out.println(str);
}
  • 以上两个例子都是输出:

2.自定义排序器,String数组按字符串长度倒序

  • 创建自定义排序器StringComparator
package com.simon.interfacedemo.sortdemo.stringdemo;

import java.util.Comparator;
/**
* @Description: 通过实现Comparator接口,实现自定义排序
*/
public class StringComparator implements Comparator<String>{
/**
* 按字符串长度降序排序
*/
@Override
public int compare(String o1, String o2) {
return o1.length() > o2.length() ? -1 : 1;
}
}

2.1 数组使用StringComparator排序器

String[] strArr = new String[]{"zhangsan","lisi","wangwu"};
//自定义排序,按字符串长度升序
Arrays.sort(strArr,new StringComparator());
System.out.println("自定义排序,按字符串长度降序排序:");
for (String str:strArr) {
System.out.println(str);
}

2.2 集合使用StringComparator排序器

List<String> strList = new ArrayList<>();
strList.add("zhangsan");
strList.add("lisi");
strList.add("wangwu");
//自定义排序,按字符串长度降序
Collections.sort(strList,new StringComparator());
System.out.println("自定义排序,按字符串长度降序排序:");
for (String str:strList) {
System.out.println(str);
}
  • 以上两个例子都是输出:

3.自定义类实现Comparable接口,使类具有排序功能

  • 自定义Student类,实现Comparable接口,重写compareTo方法,按age升序排序
public class Student implements Comparable<Student>{

    private String name;
private Integer age; public Student(String name,Integer age){
this.name = name;
this.age = age;
} public String getName() {
return name;
} /**
* 实现compareTo接口方法,按age升序。
* @param o
* @return 返回1:大于,0:等于,-1:小于
*/
@Override
public int compareTo(Student o) {
return Integer.compare(age,o.age);
} /**
* 重写toString方法,方便System.out.println打印出详细的信息。
*/
@Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}

3.1 Student数组按age升序排序

Student[] students = new Student[3];
students[0] = new Student("zhangsan",30);
students[1] = new Student("lisi",28);
students[2] = new Student("wangwu",33); System.out.println("通过student实现的默认排序,根据age升序排序:");
Arrays.sort(students);
for (Student student : students) {
System.out.println(student);
}

3.2 Student集合按age升序排序

List<Student> studentList = new ArrayList<>();
studentList.add(new Student("zhangsan",30));
studentList.add(new Student("lisi",28));
studentList.add(new Student("wangwu",33));
System.out.println("通过student实现的默认排序,根据age升序排序:");
Collections.sort(studentList);
for (Student student : studentList) {
System.out.println(student);
}
  • 以上两个例子都是输出:

4.自定义排序器,按Student的name长度升序排序

  • 创建自定义排序器StudentComparator
package com.simon.interfacedemo.sortdemo.studentdemo;

import java.util.Comparator;
/**
* @Description: 通过实现Comparator接口,实现自定义排序
*/
public class StudentComparator implements Comparator<Student>{
/**
* 按名字长度升序排序
*/
@Override
public int compare(Student o1, Student o2) { return o1.getName().length() > o2.getName().length() ? 1 : -1;
}
}

4.1 数组使用StudentComparator排序器

Student[] students = new Student[3];
students[0] = new Student("zhangsan",30);
students[1] = new Student("lisi",28);
students[2] = new Student("wangwu",33); System.out.println("通过自定义排序器实现的排序,根据名字长度排序:");
Arrays.sort(students,new StudentComparator());
for (Student student : students) {
System.out.println(student);
}

4.2 集合使用StudentComparator排序器

List<Student> studentList = new ArrayList<>();
studentList.add(new Student("zhangsan",30));
studentList.add(new Student("lisi",28));
studentList.add(new Student("wangwu",33)); System.out.println("通过自定义排序器实现的排序,根据名字长度排序:");
Collections.sort(studentList,new StudentComparator());
for (Student student : students) {
System.out.println(student);
}
  • 以上两个例子都是输出:

后续

  • 以上列出了实际开发中可能用到的数组、集合的排序方式。使用lambda还可以更简化,后续再总结出来。
  • 以上示例都可以通过我的GitHub获取完整的代码,点击获取

Java 集合、数组排序的更多相关文章

  1. java 集合数组排序

    //数组排序Integer arr[] = {3,4,2};Arrays.sort(arr);//默认升序Arrays.sort(arr,Comparator.reverseOrder());//传一 ...

  2. Java集合---Array类源码解析

    Java集合---Array类源码解析              ---转自:牛奶.不加糖 一.Arrays.sort()数组排序 Java Arrays中提供了对所有类型的排序.其中主要分为Prim ...

  3. Java集合面试题

    1.Java集合框架是什么?说出一些集合框架的优点? 每种编程语言中都有集合,最初的Java版本包含几种集合类:Vector.Stack.HashTable和Array.随着集合的广泛使用,Java1 ...

  4. 40个Java集合面试问题和答案

    Java集合框架为Java编程语言的基础,也是Java面试中很重要的一个知识点.这里,我列出了一些关于Java集合的重要问题和答案. 另外,码农网之前也整理过一篇关于Java集合面试题的文章:大公司最 ...

  5. 40个Java集合面试问题和答案【下】【转载】

    接上文:http://www.cnblogs.com/xujianbo/p/5148083.html 28.哪些集合类是线程安全的? Vector.HashTable.Properties和Stack ...

  6. Java集合框架的知识总结(1)

    说明:先从整体介绍了Java集合框架包含的接口和类,然后总结了集合框架中的一些基本知识和关键点,并结合实例进行简单分析. 1.综述 所有集合类都位于java.util包下.集合中只能保存对象(保存对象 ...

  7. Java集合框架的知识总结

    说明:面试准备,写的挺不错的. 转载地址: http://www.cnblogs.com/zhxxcq/archive/2012/03/11/2389611.html 1.综述 所有集合类都位于jav ...

  8. Java 集合系列之一:JCF集合框架概述

    容器,就是可以容纳其他Java对象的对象.Java Collections Framework(JCF)为Java开发者提供了通用的容器 java集合主要划分为四个部分: Collection(Lis ...

  9. Java集合框架总结—超详细-适合面试

    Java集合框架总结—超详细-适合面试   一.精简: A.概念汇总 1.Java的集合类主要由两个接口派生而出:Collection和Map,Collection和Map是Java集合框架的根接口, ...

  10. (转)40个Java集合面试问题和答案

    Java集合框架为Java编程语言的基础,也是Java面试中很重要的一个知识点.这里,我列出了一些关于Java集合的重要问题和答案. 另外,码农网之前也整理过一篇关于Java集合面试题的文章:大公司最 ...

随机推荐

  1. java 之断言

    今天用idea的智能提示冒出一个assert关键字,愣是没看懂!!!还是太菜了.上网查了一下,这个关键字是断言. 什么是断言? 我也说不清楚,反正就是对jvm的操作.java的错误分为两种,一种叫er ...

  2. 吴裕雄--天生自然 JAVA开发学习:Applet 基础

    import java.applet.*; import java.awt.*; public class HelloWorldApplet extends Applet { public void ...

  3. linux重定向与管道符(一)

    linux重定向和管道符 为什么要使用重定向 1.当屏幕输出的信息很重要,而且我们需要将他存下来的时候: 2.后台执行中的程序,不希望他干扰屏幕正常的输出结果时: 3.系统的例行命令,例如定时任务的执 ...

  4. Momentum(动量)方法的python实现

    Momentum方法可以说是对SGD的进一步优化,细节可以参考这里 这里用python对其进行简单实现,如下: # coding=utf-8 """ 基于小批量梯度下降来 ...

  5. [LC] 95. Unique Binary Search Trees II

    Given an integer n, generate all structurally unique BST's (binary search trees) that store values 1 ...

  6. [LC] 22. Generate Parentheses

    Given n pairs of parentheses, write a function to generate all combinations of well-formed parenthes ...

  7. ffmpeg直播系统

    1.HLS协议 http live streaming 将本地文件或者摄像头视频转成hls流文件 https://www.ffmpeg.org/ffmpeg-all.html#hls-2 2.rtmp ...

  8. 【clientX,offsetX,screenX】 【scrollWidth,clientWidth,offsetWidth】的区别

    一.深刻认识clientX,offsetX,screenX 概念(来源于网络): clientX 设置或获取鼠标指针位置相对于当前窗口的 x 坐标,其中客户区域不包括窗口自身的控件和滚动条. clie ...

  9. C++中字符串的表示与转换

    转换总结 1.char*转string:可以直接赋值. 2.char[]转string:可以直接赋值. 3.char*转char[]:不能直接赋值,可以循环char*字符串逐个字符赋值,也可以使用st ...

  10. 吴裕雄--天生自然 R语言开发学习:聚类分析

    #-------------------------------------------------------# # R in Action (2nd ed): Chapter 16 # # Clu ...