java中Arrays.sort()排序方法举例详解

 更新时间:2023年11月17日 11:38:04   作者:从0到1的旅行家  
这篇文章主要给大家介绍了关于java中Arrays.sort()排序方法举例详解的相关资料,Java Arrays.sort()方法对数组进行排序,通常情况下直接传入数组,默认升序排序,文中通过代码介绍的非常详细,需要的朋友可以参考下

Java中的Arrays.sort()方法是一种内置的排序方法,用于对数组进行排序。这是一个来自java.util.Arrays类的静态方法,用于对所有的基本数据类型对象数组以及对象数组进行排序。排序的默认顺序是升序。

一、方法重载

Arrays.sort()方法有许多重载版本,可以接受不同类型的输入,并对它们进行排序。以下是一些常见的重载版本:

  • Arrays.sort(byte[] a): 对字节型数组进行排序
  • Arrays.sort(char[] a): 对字符型数组进行排序
  • Arrays.sort(double[] a): 对双精度浮点型数组进行排序
  • Arrays.sort(float[] a): 对浮点型数组进行排序
  • Arrays.sort(int[] a): 对整型数组进行排序
  • Arrays.sort(long[] a): 对长整型数组进行排序
  • Arrays.sort(short[] a): 对短整型数组进行排序
  • Arrays.sort(Object[] a): 对对象数组进行排序,此方法要求数组中的对象必须实现了Comparable接口
  • Arrays.sort(T[] a, Comparator<? super T> c): 对对象数组进行排序,使用一个定制的Comparator对象来比较数组中的元素

二、注意事项

  • 对于对象数组,如果使用默认的Arrays.sort(Object[] a)方法进行排序,那么数组中的对象必须实现了Comparable接口。如果对象没有实现这个接口,那么在运行时会抛出ClassCastException

  • Arrays.sort(T[] a, Comparator<? super T> c)这个版本的方法允许你传入一个Comparator对象来自定义排序的规则。如果传入的Comparator对象为null,那么此方法将会使用元素的自然顺序进行排序。

  • 对于对象数组的排序,Arrays.sort()方法使用的是稳定的排序算法,这意味着等值的元素在排序后会保持他们原有的相对位置。

  • Arrays.sort()方法的时间复杂性为O(n log n)。

  • Arrays.sort()方法会对输入的数组进行直接排序,也就是说,它会改变输入数组的元素顺序。如果不希望改变原数组的元素顺序,那么在排序前需要先对数组进行复制。

三、举例

(1)对于基本数据类型的数组,排序时会按照升序排序;

int[] arr = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5};
Arrays.sort(arr); // 对数组进行排序

for (int i = 0; i < arr.length; i++) {
    System.out.print(arr[i] + " ");
}

输出结果:

1 1 2 3 3 4 5 5 5 6 9

ps:Arrays.sort() 方法使用的是快速排序算法和归并排序算法,具体使用哪一种算法取决于数组的大小和类型。当数组长度小于 Arrays.MIN_ARRAY_SORT_GRAN 时,使用插入排序算法对其进行排序。

(2)对对象数组进行排序

可以通过实现 Comparator 接口来指定比较器对象。Comparator 接口需要实现 compare() 方法,该方法接受两个对象作为参数,并返回一个整数值,用于表示这两个对象的大小关系。如果返回的值为负数,则表示第一个对象小于第二个对象,为正序;如果返回的值为正数,则表示第一个对象大于第二个对象,为逆序;如果返回的值为0,则表示两个对象相等。

import java.util.*;

class Person {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }
}

class PersonAgeComparator implements Comparator<Person> {
    @Override
    public int compare(Person o1, Person o2) {
        return o1.getAge() - o2.getAge();
    }
}

public class Main {
    public static void main(String[] args) {
        Person[] people = {
                new Person("Alice", 25),
                new Person("Bob", 20),
                new Person("Charlie", 30)
        };

        Arrays.sort(people, new PersonAgeComparator());

        for (Person p : people) {
            System.out.println(p.getName() + " " + p.getAge());
        }
    }
}

输出结果

Bob 20
Alice 25
Charlie 30

在该示例中,定义了一个 Person 类,包含两个属性 name 和 age。我们按照年龄对 Person 对象数组进行排序,创建了一个 PersonAgeComparator 类,实现了 Comparator 接口,并重写了 compare() 方法。在  main() 方法中,调用 Arrays.sort() 方法,并入 PersonAgeComparator 对象,来对 Person 对象数组进行排序。

总结

到此这篇关于java中Arrays.sort()排序方法的文章就介绍到这了,更多相关java Arrays.sort()排序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mybatis中嵌套使用foreach需要注意的坑

    mybatis中嵌套使用foreach需要注意的坑

    在使用MyBatis进行数据库操作时,如果需要在一个大的foreach标签中嵌套另一个foreach,需要注意内层foreach的item属性不能与外层重复,如果出现重复,会导致绑定参数时找不到正确的参数,从而抛出异常
    2024-09-09
  • 深入理解Spring bean加载顺序

    深入理解Spring bean加载顺序

    在默认配置下,SpringBean的加载顺序主要受到Bean定义顺序、依赖关系和生命周期回调方法的影响,本文就来了解一下Spring bean加载顺序,感兴趣的同学可以学习
    2024-10-10
  • Java异常Exception详细讲解

    Java异常Exception详细讲解

    异常就是不正常,比如当我们身体出现了异常我们会根据身体情况选择喝开水、吃药、看病、等 异常处理方法。 java异常处理机制是我们java语言使用异常处理机制为程序提供了错误处理的能力,程序出现的错误,程序可以安全的退出,以保证程序正常的运行等
    2022-07-07
  • IDEA部署Tomcat的超详细图文教程

    IDEA部署Tomcat的超详细图文教程

    最近迫于无奈从我哪破旧的Eclipse转换到了IDEA,然后就是超多的不习惯,下面这篇文章主要给大家介绍了关于IDEA部署Tomcat的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-02-02
  • Java中Spring使用Quartz任务调度定时器

    Java中Spring使用Quartz任务调度定时器

    本篇文章主要介绍了Java中Spring使用Quartz任务调度定时器,具有一定的参考价值,有兴趣的可以了解一下。
    2017-02-02
  • 一篇文章搞定Struts2的类型转换

    一篇文章搞定Struts2的类型转换

    这篇文章主要介绍了关于Struts2类型转换的相关资料,文中主要介绍了Struts2的类型转换器和自定义类型转换器的实现,有需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-02-02
  • java中的三种取整函数总结

    java中的三种取整函数总结

    下面小编就为大家带来一篇java中的三种取整函数总结。希望对大家有所帮助。一起跟随小编过来看看吧,祝大家游戏愉快哦
    2016-11-11
  • 通过自定制LogManager实现程序完全自定义的logger

    通过自定制LogManager实现程序完全自定义的logger

    本章主要阐述怎么完全定制化LogManager来实现应用程序完全自定制的logger,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-03-03
  • java 父类子类有同名方法时如何调用的实现

    java 父类子类有同名方法时如何调用的实现

    这篇文章主要介绍了java 父类子类有同名方法时如何调用的实现,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • JavaWeb Spring注解Annotation深入学习

    JavaWeb Spring注解Annotation深入学习

    这篇文章主要为大家详细介绍了JavaWeb Spring注解Annotation,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09

最新评论