0
点赞
收藏
分享

微信扫一扫

SNAPCENTER 备份管理软件:完善的保护功能

DYBOY 2024-06-02 阅读 9
java

Arrays:

用来操作数组的工具类。

解释说明:

只要知道代码这么写就可以了。

package cn.ensource.d5_arrays;

import java.util.Arrays;
import java.util.function.IntToDoubleFunction;

public class ArraysTest1 {
    public static void main(String[] args) {
        //
        int[] arr = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
        System.out.println(Arrays.toString(arr));

        int[] arr2 = Arrays.copyOfRange(arr, 1, 4); // 包前不包后
        System.out.println(Arrays.toString(arr2));

        int[] arr3 = Arrays.copyOf(arr, 20);   // 对数组进行扩容
        System.out.println(Arrays.toString(arr3));

        double[] prices = {99.8, 128, 100.0};
        System.out.println(Arrays.toString(prices));

        // 把所有的数据打八折,然后再存进去
        // 匿名内部类
        Arrays.setAll(prices, new IntToDoubleFunction() {
            @Override
            public double applyAsDouble(int value) {
                return prices[value] * 0.8;
            }
        });
        System.out.println(Arrays.toString(prices));

        // 对数组进行排序
        Arrays.sort(prices);
        System.out.println(Arrays.toString(prices));


    }
}

 

如果数组中存储的是对象,如何排序?

方法一:让该对象的类实现Comparable(比较规则)接口,然后重写Comparable方法,自己来制定比较细则。

方法二:下面这个sort方法,创建Comparator比较接口的匿名内部类对象,然后自己制定比较规则。

Student类:

package cn.ensource.d5_arrays;

public class Student implements Comparable<Student>{
    private String name;
    private int age;
    private double height;

    public Student() {
    }

    public Student(String name, int age, double height) {
        this.name = name;
        this.age = age;
        this.height = height;
    }

    // 指定比较规则
    // this和student两个对象
    @Override
    public int compareTo(Student student) {
        // 约定:如果左边对象大于右边对象,请您返回正整数
        // 如果左边对象小于右边对象,返回负整数
        // 如果左边对象等于右边对象,请您一定返回0
        // 按照年龄升序排列
//        if(this.age > student.age){
//            return 1;
//        }else if(this.age < student.age){
//            return -1;
//        }
//        return 0;
        return this.age - student.age;   // 升序
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public double getHeight() {
        return height;
    }

    public void setHeight(double height) {
        this.height = height;
    }

    @Override
    public String toString() {
        return "Student{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", height=" + height +
                '}';
    }
}

测试类:

package cn.ensource.d5_arrays;

import java.util.Arrays;

public class ArrayTest2 {
    public static void main(String[] args) {
        // 目标:掌握如何对数组中的对象进行排序
        Student[] students = new Student[4];
        students[0] = new Student("蜘蛛精", 18, 169.5);
        students[1] = new Student("狐狸精", 22, 163.8);
        students[2] = new Student("紫霞", 33, 163.8);
        students[3] = new Student("至尊宝", 44, 167.5);

        // sort(类型[] arr] 对数组进行排序
        Arrays.sort(students);

        // 为排序对象自定义排序规则
        System.out.println(Arrays.toString(students));

    }
}

方式二: 

package cn.ensource.d5_arrays;

import java.util.Arrays;
import java.util.Comparator;

public class ArrayTest2 {
    public static void main(String[] args) {
        // 目标:掌握如何对数组中的对象进行排序
        Student[] students = new Student[4];
        students[0] = new Student("蜘蛛精", 18, 169.5);
        students[1] = new Student("狐狸精", 22, 163.8);
        students[2] = new Student("紫霞", 33, 163.8);
        students[3] = new Student("至尊宝", 44, 167.5);

        // sort(类型[] arr] 对数组进行排序
//        Arrays.sort(students);

        // 为排序对象自定义排序规则
//        System.out.println(Arrays.toString(students));

        // public static <T> void sort(T[] arr, Comparator<? super T> c)
        // 参数一:需要排序的数组
        // 参数二:Comparator比较器对象,c用来制定对象的比较规则
        Arrays.sort(students, new Comparator<Student>() {

            @Override
            public int compare(Student o1, Student o2) {
                // 制定比较规则,左边对象是o1, 右边对象是o2
//                if(o1.getHeight() > o2.getHeight()) {
//                    return 1;
//                }else if(o1.getHeight() < o2.getHeight()) {
//                    return -1;
//                }
//                return 0;
                return Double.compare(o1.getHeight(), o2.getHeight());
            }
        });
        System.out.println(Arrays.toString(students));
    }
}

举报

相关推荐

0 条评论