resumen colecciones

Colecciones (entender)   

    (1) son herramientas que operan en el conjunto de

    (2) se inscribe: Colecciones y recogida de diferencia

        R: Collection es una colección de interfaz de nivel superior separada, hay dos sub-interfaces y Set List

        B: Colecciones está operando para un conjunto de herramientas, se pueden establecer para la ordenación y búsqueda, etc.

    (3) común algunas de las formas pequeñas:

        A: public static <T> vacío especie (List <T> lista): ordenar por orden natural por defecto.

        B: public static <T> int busquedaBinaria (Lista lista, tecla T <?>): 二 分 查找

        C: public static <T> T max (Colección coll <?>): 最大值

        D: static public void inversa (Lista lista <?>): 反转

        E: public static void aleatoria (listado <?>): Permutación aleatoria

    (4) Caso

        A: Ordenar ArrayList almacenar un conjunto de objetos personalizados      


public class Student implements Comparable<Student> {

    private String name;

    private int age;



   //构造器,getXXX+setXXx....

    @Override

    public int compareTo(Student s) {

        int num = this.age - s.age;

        int num2 = num == 0 ? this.name.compareTo(s.name) : num;

        return num2;

    }

}
/*

 * Collections可以针对ArrayList存储基本包装类的元素排序,存储自定义对象排序需要比较器。

 */

public class CollectionsDemo {

    public static void main(String[] args) {

        // 创建集合对象

        List<Student> list = new ArrayList<Student>();



        // 创建学生对象

        Student s1 = new Student("林青霞", 27);

        Student s2 = new Student("风清扬", 30);

        Student s3 = new Student("刘晓曲", 28);

        Student s4 = new Student("武鑫", 29);

        Student s5 = new Student("林青霞", 27);



        // 添加元素对象

        list.add(s1);

        list.add(s2);

        list.add(s3);

        list.add(s4);

        list.add(s5);



        // 排序

        // 自然排序

        // Collections.sort(list);

        // 比较器排序

        // 如果同时有自然排序和比较器排序,以比较器排序为主

        Collections.sort(list, new Comparator<Student>() {

            @Override

            public int compare(Student s1, Student s2) {

                int num = s2.getAge() - s1.getAge();

                int num2 = num == 0 ? s1.getName().compareTo(s2.getName())

                        : num;

                return num2;

            }

        });



        // 遍历集合

        for (Student s : list) {

            System.out.println(s.getName() + "---" + s.getAge());

        }

    }

}

 

Publicados 114 artículos originales · ganado elogios 52 · Vistas a 20000 +

Supongo que te gusta

Origin blog.csdn.net/Smile_Sunny521/article/details/89703503
Recomendado
Clasificación