java小知识点:比较器

java中自主排序主要根据一个Comparator类来实现。

他内部实现用的是Timsort策略。大概思想是说将整个集合分成几个小段,每个小段分别排序,然后再拼在一起。

主要用法是传入两个数(也可以不是Integer或int类型,这里只是把他们都统称为数),然后根据返回值来判断这两个数哪个在前那个在后。比如a大于b的时候返回一个负数,那么a在b的前面,如果返回正数,那么a在b后面。

此外有的类还实现了Comparable接口。这些类需要重写compareTo方法来定义他的排列顺序。这样这个类就可以被Collections.sort直接排序,而不需要再人为写一次排序器。当然,如果又自己写了一个比较器的话(Comparator),自己写的比较器优先级更高

关于compare接口的实现和Comparator类的区别,以下是gpt的一个总结

Comparartor在使用时,一般是以下的语法,这样来实现一个内部匿名类

java 复制代码
Collections.sort(lsit, new Comparator(){
    @Override
    public int compare(){
        ****
        return *
    }    
})

或者也可以用lambda表达式或Comparator的内部实现

相关推荐
毕设源码-钟学长2 分钟前
【开题答辩全过程】以 基于PHP的家常菜谱教程网站为例,包含答辩的问题和答案
开发语言·php
周杰伦_Jay2 分钟前
【Go/Python/Java】基础语法+核心特性对比
java·python·golang
sszdlbw4 分钟前
后端springboot框架入门学习--第一篇
java·spring boot·学习
消失的旧时光-19437 分钟前
用 C 实现一个简化版 MessageQueue
c语言·开发语言
小鹿学程序7 分钟前
jdk配置完之后java -version还是默认的jdk版本如何更改
java·开发语言·python
至善迎风8 分钟前
Bun:下一代 JavaScript 运行时与工具链
开发语言·javascript·ecmascript·bun
她说彩礼65万10 分钟前
C# 反射
java·算法·c#
程序员-King.12 分钟前
【Qt开源项目】— ModbusScope-day 5
开发语言·qt
老秦包你会17 分钟前
QT第五课------QT系统相关------线程
开发语言·qt
hhy_smile18 分钟前
Android 与 java 设计笔记
android·java·笔记