java自学笔记12:java中的集合框架(下)List

2023-11-15

一.学生选课—判断List中课程是否存在

这里写图片描述

思考
:在课程序列中,如何判断是否包含某门或者某几门课程?
:如果课程序列包含某门课程,如何判断该课程的索引位置?
:在学生映射表中,如何判断是否包含某个学生ID?
:又该如何判断是否包含某个学生对象?
:如果想把课程或者学生对象,按照课程名称或者学生姓名排序又该怎么办?按照ID排序呢?
这里写图片描述

SetTest类代码示例:

package com.vishuo.collection;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Scanner;

public class SetTest {

    public List<Course> coursesToSelect;

    private Scanner console;

    public SetTest(){
        coursesToSelect = new ArrayList<Course>();
        console = new Scanner(System.in);
    }


    public void testAdd() {
        // 创建一个课程对象,并通过调用add方法,添加到备选课程List中
        Course cr1 = new Course("1", "数据结构");
        coursesToSelect.add(cr1);
        Course temp = (Course) coursesToSelect.get(0);// 对象存入集合都变成object类型,取出时需要类型转换
        ;
//      System.out.println("添加了课程:" + temp.id + ":" + temp.name);

        Course cr2 = new Course("2", "C语言");
        coursesToSelect.add(0, cr2);
        Course temp2 = (Course) coursesToSelect.get(0);
//      System.out.println("添加了课程:" + temp2.id + ":" + temp2.name);

//      coursesToSelect.add(cr1);
//      Course temp0 = (Course) coursesToSelect.get(2);// 对象存入集合都变成object类型,取出时需要类型转换
//      ;
//      System.out.println("添加了课程:" + temp0.id + ":" + temp0.name);

        /**
         * Course cr3 = new Course("3", "test"); coursesToSelect.add(4,cr3);
         * 会报数组下标越界异常
         * 
         * 添加了课程:1:数据结构Exception in thread "main" 添加了课程:2:C语音
         * java.lang.IndexOutOfBoundsException: Index: 4, Size: 2 at
         * java.util.ArrayList.rangeCheckForAdd(ArrayList.java:661) at
         * java.util.ArrayList.add(ArrayList.java:473) at
         * com.vishuo.collection.ListTest.testAdd(ListTest.java:35) at
         * com.vishuo.collection.ListTest.main(ListTest.java:41)
         */

        Course[] coures = { new Course("3", "离散数学"), new Course("4", "汇编语音") };
        coursesToSelect.addAll(Arrays.asList(coures));
        Course temp3 = (Course) coursesToSelect.get(2);
        Course temp4 = (Course) coursesToSelect.get(3);
//      System.out.println("添加了两门课程:" + temp3.id + ":" + temp3.name + ";" + temp4.id + ":" + temp4.name);

        Course[] course2 = { new Course("5", "高等数学"), new Course("6", "大学英语") };
        coursesToSelect.addAll(2, Arrays.asList(course2));

        Course temp5 = (Course) coursesToSelect.get(2);
        Course temp6 = (Course) coursesToSelect.get(3);
//      System.out.println("添加了两门课程:" + temp5.id + ":" + temp5.name + ";" + temp6.id + ":" + temp6.name);

    }

    /*
     * 通过for each 方法访问集合元素
     */
    public void testForEach() {
        System.out.println("有如下课程待选(通过for each访问):");
        for (Object obj : coursesToSelect) {
            Course cr = (Course) obj;
            System.out.println("课程:" + cr.id + ":" + cr.name);
        }
    }

    /*
     * 测试List的contains方法
     * */
    public void testListContains(){
        //取得备选课程序列的第0个元素
        Course course = coursesToSelect.get(1);
        //打印输出coursesToSelected是否包含course对象
        System.out.println("取得课程:"+course.name);
        System.out.println("备选课程中是否包含课程:"+course.name+","+coursesToSelect.contains(course));
        //提示输入课程名称
        System.out.println("请输入课程名称:");
        String name = console.next();
        //创建一个新的课程对象,ID和名称,与course对象完全一样
        Course course2 = new Course();
        course2.name = name;

        System.out.println("新创建课程:"+course2.name);
        System.out.println("备选课程中是否包含课程:"+course2.name+","+coursesToSelect.contains(course2));
    }

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        SetTest st = new SetTest();
        st.testAdd();
        st.testListContains();
//        st.testForEach();
//        //创建一个学生对象
//        Student student = new Student("1","小敏");
//        System.out.println("欢迎学生:"+student.name+"选课!");
//        //创建一个Scanner对象,用来接收从键盘输入的课程ID
//        Scanner console = new Scanner(System.in);
//        
//        for(int i = 0;i<3;i++){
//          System.out.println("请输入课程ID");
//          String courseId = console.next();
//          for(Course cr: st.coursesToSelect){
//              if(cr.id.equals(courseId)){
//                  student.courses.add(cr);
//                  /*
//                   * Set中,添加某个对象,无论添加多少次
//                   * 最终只会保留一个该对象(的引用)
//                   * 并且,保留的是第一次添加的哪一个
//                   */
                    student.courses.add(cr);
//              }
//          }
//        }
//        st.testForEachForsET(student);
    }

    public void testForEachForsET(Student student){
        //打印输出,学生所选的课程!
        System.out.println("共选择了:" + student.courses.size() +"门课程");
        for(Course cr:student.courses){
            System.out.println("选择了课程:" +cr.id +":"+cr.name);
        }
    }
}

这里写图片描述

二.学生选课—判断Set中课程是否存在

Course类重写hashCode和equals方法,可通过编辑器直接生成
这里写图片描述

package com.vishuo.collection;

/*
 * 课程类:在实际开发中,要实现属性的私有化,通过setter和getter方法进行访问
 * */
public class Course {

    public String id;
    public String name;

    public Course(String id, String name) {
        this.id = id;

        this.name = name;
    }

    public Course() {

    }

    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((name == null) ? 0 : name.hashCode());
        return result;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (!(obj instanceof Course))
            return false;
        Course other = (Course) obj;
        if (name == null) {
            if (other.name != null)
                return false;
        } else if (!name.equals(other.name))
            return false;
        return true;
    }

}

SetTest类修改如下:

package com.vishuo.collection;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Scanner;

public class SetTest {

    public List<Course> coursesToSelect;

    private Scanner console;

    public Student student;

    public SetTest() {
        coursesToSelect = new ArrayList<Course>();
        console = new Scanner(System.in);
    }

    public void testAdd() {
        // 创建一个课程对象,并通过调用add方法,添加到备选课程List中
        Course cr1 = new Course("1", "数据结构");
        coursesToSelect.add(cr1);
        Course temp = (Course) coursesToSelect.get(0);// 对象存入集合都变成object类型,取出时需要类型转换
        ;
        // System.out.println("添加了课程:" + temp.id + ":" + temp.name);

        Course cr2 = new Course("2", "C语言");
        coursesToSelect.add(0, cr2);
        Course temp2 = (Course) coursesToSelect.get(0);
        // System.out.println("添加了课程:" + temp2.id + ":" + temp2.name);

        // coursesToSelect.add(cr1);
        // Course temp0 = (Course) coursesToSelect.get(2);//
        // 对象存入集合都变成object类型,取出时需要类型转换
        // ;
        // System.out.println("添加了课程:" + temp0.id + ":" + temp0.name);

        /**
         * Course cr3 = new Course("3", "test"); coursesToSelect.add(4,cr3);
         * 会报数组下标越界异常
         * 
         * 添加了课程:1:数据结构Exception in thread "main" 添加了课程:2:C语音
         * java.lang.IndexOutOfBoundsException: Index: 4, Size: 2 at
         * java.util.ArrayList.rangeCheckForAdd(ArrayList.java:661) at
         * java.util.ArrayList.add(ArrayList.java:473) at
         * com.vishuo.collection.ListTest.testAdd(ListTest.java:35) at
         * com.vishuo.collection.ListTest.main(ListTest.java:41)
         */

        Course[] coures = { new Course("3", "离散数学"), new Course("4", "汇编语音") };
        coursesToSelect.addAll(Arrays.asList(coures));
        Course temp3 = (Course) coursesToSelect.get(2);
        Course temp4 = (Course) coursesToSelect.get(3);
        // System.out.println("添加了两门课程:" + temp3.id + ":" + temp3.name + ";" +
        // temp4.id + ":" + temp4.name);

        Course[] course2 = { new Course("5", "高等数学"), new Course("6", "大学英语") };
        coursesToSelect.addAll(2, Arrays.asList(course2));

        Course temp5 = (Course) coursesToSelect.get(2);
        Course temp6 = (Course) coursesToSelect.get(3);
        // System.out.println("添加了两门课程:" + temp5.id + ":" + temp5.name + ";" +
        // temp6.id + ":" + temp6.name);

    }

    /*
     * 通过for each 方法访问集合元素
     */
    public void testForEach() {
        System.out.println("有如下课程待选(通过for each访问):");
        for (Object obj : coursesToSelect) {
            Course cr = (Course) obj;
            System.out.println("课程:" + cr.id + ":" + cr.name);
        }
    }

    /*
     * 测试List的contains方法
     */
    public void testListContains() {
        // 取得备选课程序列的第0个元素
        Course course = coursesToSelect.get(1);
        // 打印输出coursesToSelected是否包含course对象
        System.out.println("取得课程:" + course.name);
        System.out.println("备选课程中是否包含课程:" + course.name + "," + coursesToSelect.contains(course));
        // 提示输入课程名称
        System.out.println("请输入课程名称:");
        String name = console.next();
        // 创建一个新的课程对象,ID和名称,与course对象完全一样
        Course course2 = new Course();
        course2.name = name;

        System.out.println("新创建课程:" + course2.name);
        System.out.println("备选课程中是否包含课程:" + course2.name + "," + coursesToSelect.contains(course2));
    }

    // 创建学生对象并选课
    public void createStudentAndSelectCours() {
        // 创建一个学生对象
        student = new Student("1", "小敏");
        System.out.println("欢迎学生:" + student.name + "选课!");
        // 创建一个Scanner对象,用来接收从键盘输入的课程ID
        Scanner console = new Scanner(System.in);

        for (int i = 0; i < 3; i++) {
            System.out.println("请输入课程ID");
            String courseId = console.next();
            for (Course cr : coursesToSelect) {
                if (cr.id.equals(courseId)) {
                    student.courses.add(cr);
                    /*
                     * Set中,添加某个对象,无论添加多少次 最终只会保留一个该对象(的引用) 并且,保留的是第一次添加的哪一个
                     */
                    // student.courses.add(cr);
                }
            }
        }
    }

    /*
     * 测试Set的contains方法
     */
    public void testSetContains() {
        // 提示输入课程名称
        System.out.println("请输入学生已选的课程名称:");
        String name = console.next();
        // 创建一个新的课程对象,ID和名称,与course对象完全一样
        Course course2 = new Course();
        course2.name = name; 
        System.out.println("新创建课程:" + course2.name);
        System.out.println("备选课程中是否包含课程:" + course2.name + "," + student.courses.contains(course2));
    }

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        SetTest st = new SetTest();
        st.testAdd();
//      st.testListContains();
         st.testForEach();
        // st.testForEachForsET(student);

        st.createStudentAndSelectCours();
        st.testSetContains();
    }

    public void testForEachForsET(Student student) {
        // 打印输出,学生所选的课程!
        System.out.println("共选择了:" + student.courses.size() + "门课程");
        for (Course cr : student.courses) {
            System.out.println("选择了课程:" + cr.id + ":" + cr.name);
        }
    }
}

三.学生选课—获取List中课程的位置

如果课程序列包含某门课程,如何判断该课程的索引位置?

这里写图片描述

//通过indexOf方法来取得某元素的索引位置
        if(coursesToSelect.contains(course2))
            System.out.println("课程:"+course2.name+"的索引位置为:"+coursesToSelect.indexOf(course2));

四.学生选课—判断Map中是否包含指定的key和value

使用MapTest类进行示例:

package com.vishuo.collection;

import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Scanner;
import java.util.Set;

public class MapTest {

    /*
     * 用来承装学生类型对象
     */
    public Map<String, Student> students;
    private Scanner console;

    /*
     * 在构造器中初始化students属性
     */
    public MapTest() {
        this.students = new HashMap<String, Student>();
    }

    /*
     * 测试添加:输入学生ID,判断是否被占用 若未被占用,则输入姓名,创建新学生对象,并且添加到student中
     */
    public void testPut() {
        console = new Scanner(System.in);

        int i = 0;
        while (i < 3) {
            System.out.println("请输入学生ID:");
            String ID = console.next();
            // 判断该ID是否被占用
            Student st = students.get(ID);
            if (st == null) {
                // 提示输入学生姓名
                System.out.println("请输入学生姓名:");
                String name = console.next();
                // 创建新的学生对象
                Student newStudent = new Student(ID, name);
                // 通过调用students的put方法,添加ID-学生映射
                students.put(ID, newStudent);
                System.out.println("成功添加学生:" + students.get(ID).name);
                i++;
            } else {
                System.out.println("该学生ID已被占用!");
                continue;
            }
        }
    }
    /*
     * 测试Map的keySet方法
     */
    public void testKeySet(){
        //通过keySet方法,返回Map中的所有“键”的Set集合
        Set<String> keySet = students.keySet();
        //取得students的容量
        System.out.println("总共有:"+students.size()+"个学生");
        //遍历keySet,取得每一个键,再调用get方法取得每个键对应的value
        for(String stuId:keySet){
            Student st = students.get(stuId);
            if(st != null){
                System.out.println("学生:"+st.name);
            }
        }
    }

    /*
     * 测试删除Map中的映射
     */
    public void testRemove() {

        // 获取从键盘上输入的待删除学生ID字符串
        console = new Scanner(System.in);
        while(true){
            // 提示输入待删除的学生的ID
            System.out.println("请输入要删除的学生ID!");
            String ID = console.next();
            //判断该ID是否有对应的学生对象
            Student st = students.get(ID);
            if(st == null){
                //提示输入的ID并不存在
                System.out.println("该ID不存在!");
                continue;
            }
            students.remove(ID);
            System.out.println("成功删除学生:"+st.name);
            break;
        }
    }

    /*
     * 通过entrySet方法来遍历Map
     */
    public void testEntrySet(){
      //通过entrySet方法,返回Map中的所有键值对
        Set<Entry<String,Student>> entrySet  =students.entrySet();
        for(Entry<String,Student> entry:entrySet){
            System.out.println("取得键:"+entry.getKey());
            System.out.println("对应的值为:"+entry.getValue().name);
        }
    }

    /*
     * 利用put方法修改Map中的映射
     */
    public void testModify(){
      //提示输入要修改的学生ID
        System.out.println("请输入要修改的学生ID:");
        //创建一个Scanner对象,去获取从键盘上输入的学生ID字符串
        console = new Scanner(System.in);
        while(true){
            //取得从键盘输入的学生ID
            String stuID = console.next();
            //从students中查找该学生ID对应的学生对象
            Student student = students.get(stuID);
            if(student ==null){
                System.out.println("该ID不存在!请重新输入");
                continue;
            }
            //提示当前对应的学生对象的姓名
            System.out.println("当前该学生ID,所对应的学生为:"+student.name);
            //提示输入新的学生姓名,来修改已有的映射
            System.out.println("请输入新的学生姓名:");
            String name = console.next();
            Student newSudent = new Student(stuID,name);
            students.put(stuID, newSudent);
            System.out.println("修改成功!");
            break;
        }
    }

    /*
     * 测试Map中,是否包含某个key值或某个Value值
     * 
     * */
    public void testContainsKeyOarValue(){
        //提示输入学生id
        System.out.println("请输入要查询的学生ID:");
        Scanner console = new Scanner(System.in);
        String id =console.next();

        //在Map中,用containsKey()方法,来判断是否包含某个key值
        System.out.println("您输入的学生ID为:"+id+",在学生映射表中是否存在:"+students.containsKey(id));
        if(students.containsKey(id))
            System.out.println("对应的学生为:"+students.get(id).name);

        //提示输入学生姓名
        System.out.println("请输入要查询的学生姓名");
        String name = console.next();
        //用containsValue()方法,来判断是否包含某个Value值
        if(students.containsValue(new Student(null, name)))
            System.out.println("在学生映射表中,确实包含学生:"+name);
        else
            System.out.println("在学生映射表中不存在该学生的!");
    }

    public static void main(String[] args) {
        // TODO Auto-generated method stub
         MapTest mt =new MapTest();
         mt.testPut();
         mt.testKeySet();
//         mt.testRemove();
//         mt.testEntrySet();
//         mt.testModify();
//         mt.testEntrySet();
         mt.testContainsKeyOarValue();
    }

}

注意,也同时需要在Student学生类当中,重写equals和hashCode

package com.vishuo.collection;

import java.util.HashSet;
import java.util.Set;//Set和List一样,都是Collection的子接口

/*
 * 学生类
 * 
 * */
public class Student {
  public String id;
  public String name;

  public Set<Course> courses;

  public Student(String id,String name){
      this.id = id;
      this.name = name;
      //实例化
      this.courses  =new HashSet<Course>();
  }

/* (non-Javadoc)
 * @see java.lang.Object#hashCode()
 */
@Override
public int hashCode() {
    final int prime = 31;
    int result = 1;
    result = prime * result + ((name == null) ? 0 : name.hashCode());
    return result;
}

/* (non-Javadoc)
 * @see java.lang.Object#equals(java.lang.Object)
 */
@Override
public boolean equals(Object obj) {
    if (this == obj)
        return true;
    if (obj == null)
        return false;
    if (!(obj instanceof Student))
        return false;
    Student other = (Student) obj;
    if (name == null) {
        if (other.name != null)
            return false;
    } else if (!name.equals(other.name))
        return false;
    return true;
}
}

五.应用Collections.sort()实现List排序

Arrays类
java.util.Arrays:包含操作数组的各种静态方法

Collections工具类:
java.util.Collections:是java集合框架中,用来操作集合对象的工具类,也是java集合框架的成员
sort()(排序)方法

这里写图片描述

练习:利用Collections.sort()方法对泛型为String的List进行排序版本2:
1.创建完List之后,往其中添加十条随机字符串
2.每条字符串的长度为10以内的随机整数
3.每条字符串的每个字符都为随机生成的字符,字符可以重复
4.每条随机字符串不可重复

package com.vishuo.collection;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Random;

/*
 * 将要完成:
 * 1.通过Collections.sort()方法,对Integer泛型的List进行排序;
 * 2.对String泛型的List进行排序;
 * 3.对其他类型泛型的List进行排序,以Student为例。
 */
public class CollectionsTest {

    /*
     * 1.通过Collections.sort()方法,对Integer泛型的List进行排序;
     * 创建一个Integer泛型的List,插入十个100以内的不重复的随机整数 调用Collections.sort()方法对其进行排序
     */
    public void testSort1() {
        List<Integer> integerList = new ArrayList<Integer>();
        // 插入十个100以内的不重复随机整数
        Random random = new Random();
        Integer k;
        for (int i = 0; i < 10; i++) {
            do {
                k = random.nextInt(100);
            } while (integerList.contains(k));
            integerList.add(k);
            System.out.println("成功添加整数:" + k);
        }
        System.out.println("————————————排序前—————————————");
        for (Integer integer : integerList) {
            System.out.println("元素:" + integer);
        }
        Collections.sort(integerList);
        System.out.println("----------——排序后-------------");
        for (Integer integer : integerList) {
            System.out.println("元素:" + integer);
        }
    }

    /*
     * 2.对String泛型的List进行排序; 创建String泛型的list,添加三个乱序的String元素,
     * 调用sort方法,再次输出排序后的顺序
     */
    public void testSort2() {
        List<String> stringList = new ArrayList<String>();
        stringList.add("microsoft");
        stringList.add("google");
        stringList.add("lenovo");
        System.out.println("____________排序前————————————————");
        for (String string : stringList) {
            System.out.println("元素:" + string);
        }
        Collections.sort(stringList);
        System.out.println("————————————排序后———————————————");
        for (String string : stringList) {
            System.out.println("元素:" + string);
        }
    }

    /*
     * Exercise: 1.创建完List<String>之后,往其中添加十条随机字符串 2.每条字符串的长度为10以内的随机整数
     * 3.每条字符串的每个字符都为随机生成的字符,字符可以重复 4.每条随机字符串不可重复
     */
    public void exercise() {

        List<String> stringList = new ArrayList<String>();
        for (int i = 0; i < 10; i++) {// 1.创建完List<String>之后,往其中添加十条随机字符串

            StringBuilder tempString = new StringBuilder();
            Random random = new Random();
            Character[] ku = { '0', 'A', 'a' };
            do {
                int k = (int) (Math.random() * 10);// 2.每条字符串的长度为10以内的随机整数
                for (int j = 0; j <= k; j++) {
                    int t = random.nextInt(3);
                    if (t == 0) {
                        tempString.append((char) (ku[t].charValue() + random.nextInt(10)));
                    } else {
                        tempString.append((char) (ku[t].charValue() + random.nextInt(26)));
                    }
                }
            } while (stringList.contains(tempString.toString()));
            stringList.add(tempString.toString());
        }
        System.out.println("-------------排序前-------------");
        for (String st : stringList) {
            System.out.println("元素:" + st);
        }
        Collections.sort(stringList);
        System.out.println("-------------排序后-------------");
        for (String st : stringList) {
            System.out.println("元素:" + st);
        }

        StringBuilder st = new StringBuilder();// 构建StringBuilder类
        List<String> stringlist = new ArrayList<String>();
        String str = "0123456789abcdefghijklmnobqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
        for (int i = 0; i < 10; i++) {// 10条字符串
            Random random = new Random();
            do {
                for (int j = 0; j < random.nextInt(9) + 1; j++) {// 建立10长度以内的字符串
                    int k = random.nextInt(61);
                    st.append(str.charAt(k));
                } // 防止字符串重复,并且把st转化为String类,使其满足泛型,被contains方法调用
            } while (stringlist.contains(st.toString()));
            stringlist.add(st.toString());
            st = new StringBuilder();// 重新构造st,防止其接着加字符,起到让st字符串"清零"的作用
        }
        System.out.println("------排序前------");
        for (String string : stringlist) {
            System.out.println("元素:" + string);
        }
        Collections.sort(stringlist);
        System.out.println("------排序后------");
        for (String string : stringlist) {
            System.out.println("元素:" + string);
        }
    }

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        CollectionsTest ct = new CollectionsTest();
        ct.testSort1();
        ct.testSort2();
        ct.exercise();
    }

}

六.学生选课—尝试对学生序列排序

这里写图片描述

Comparable&Comparator简介
这里写图片描述

这里写图片描述

Comparable____默认比较规则:
Comparable接口—可比较的,实现该接口表示:这个类的实例可以比较大小,可以进行自然排序,定义了默认的比较规则,其实现类需要实现compareTo()方法
compareTo()方法返回正数表示大,负数表示小,0表示相等。

Comparator_____临时比较规则:
comparator接口—比较工具接口,用于定义临时比较规则,而不是默认比较规则,其实现类需要实现compare()方法,Comparator和Comparable都是java集合框架的成员

这里写图片描述

修改Student类
实现Comparable接口,按照学生id进行比较 注意实现compareTo方法

package com.vishuo.collection;

import java.util.HashSet;
import java.util.Set;//Set和List一样,都是Collection的子接口

/*
 * 学生类
 * 实现Comparable接口,按照学生id进行比较 注意实现compareTo方法
 * */
public class Student implements Comparable<Student> {
    public String id;
    public String name;

    public Set<Course> courses;

    public Student(String id, String name) {
        this.id = id;
        this.name = name;
        // 实例化
        this.courses = new HashSet<Course>();
    }

    /*
     * (non-Javadoc)
     * 
     * @see java.lang.Object#hashCode()
     */
    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((name == null) ? 0 : name.hashCode());
        return result;
    }

    /*
     * (non-Javadoc)
     * 
     * @see java.lang.Object#equals(java.lang.Object)
     */
    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (!(obj instanceof Student))
            return false;
        Student other = (Student) obj;
        if (name == null) {
            if (other.name != null)
                return false;
        } else if (!name.equals(other.name))
            return false;
        return true;
    }
    @Override
    public int compareTo(Student o){
        return this.id.compareTo(o.id);
    }
}

CollectionsTest类中,实现代码示例:

package com.vishuo.collection;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Random;

/*
 * 3.对其他类型泛型的List进行排序,以Student为例。
 */
public class CollectionsTest {
    /*
     * 3.对其他类型泛型的List进行排序,以Student为例。
     */
    public void testSort3(){
        List<Student>studentList = new ArrayList<Student>();

        String[]names = {"Mike","Angela","Lucy","nice"};
        Random random = new Random();
        Integer k = null;
        for(int i=0;i<4;i++){
            do{

                if(i==3){
                    studentList.add(new Student(10000+"",names[i]));
                }else{
                    k=random.nextInt(1000);
                    studentList.add(new Student(k+"",names[i]));
                }
            }while(studentList.contains(k));
        }

        System.out.println("______________排序前————————————————");
        for(Student student:studentList){
            System.out.println("学生:"+student.id+":"+student.name);
        }
        //按照字符串的排序规则进行排序 先数字后字母,数字0-9,字母A-Z,a-z的顺序
        Collections.sort(studentList);
        System.out.println("____________排序后——————————————");
        for(Student student:studentList){
            System.out.println("学生:"+student.id+":"+student.name);
        }

    }
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        CollectionsTest ct = new CollectionsTest();
        ct.testSort3();
    }

}

然后演示Comparator接口实现
新建类StudentComparator,实现Comparator接口implements Comparator泛型指定Student

package com.vishuo.collection;

import java.util.Comparator;

public class StudentComparator implements Comparator<Student> {

    @Override
    public int compare(Student o1, Student o2) {
        // TODO Auto-generated method stub
        return o1.name.compareTo(o2.name);
    }

}

CollectionsTest代码修改如下

package com.vishuo.collection;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Random;

/*
 * 3.对其他类型泛型的List进行排序,以Student为例。
 */
public class CollectionsTest {
    /*
     * 3.对其他类型泛型的List进行排序,以Student为例。
     */
    public void testSort3(){
        List<Student>studentList = new ArrayList<Student>();

        String[]names = {"Mike","Angela","Lucy","nice"};
        Random random = new Random();
        Integer k = null;
        for(int i=0;i<4;i++){
            do{

                if(i==3){
                    studentList.add(new Student(10000+"",names[i]));
                }else{
                    k=random.nextInt(1000);
                    studentList.add(new Student(k+"",names[i]));
                }
            }while(studentList.contains(k));
        }

        System.out.println("______________排序前————————————————");
        for(Student student:studentList){
            System.out.println("学生:"+student.id+":"+student.name);
        }
        //按照字符串的排序规则进行排序 先数字后字母,数字0-9,字母A-Z,a-z的顺序
        Collections.sort(studentList);
        System.out.println("____________排序后——————————————");
        for(Student student:studentList){
            System.out.println("学生:"+student.id+":"+student.name);
        }
        Collections.sort(studentList,new StudentComparator());
        System.out.println("___________按照姓名排序后——————————————");
        for(Student student:studentList){
            System.out.println("学生:"+student.id+":"+student.name);
    }
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        CollectionsTest ct = new CollectionsTest();
        ct.testSort3();
    }

}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

java自学笔记12:java中的集合框架(下)List 的相关文章

  • 哪个类调用了我的静态方法?

    假设我有一个带有静态方法的 Java 类 如下所示 class A static void foo Which class invoked me 进一步假设 A 类有任意数量的子类 class B extends A class C ext
  • 在 MongoDB Java 驱动程序中如何使用 $filter

    我有一个适用于 MQL 的查询 我需要将其翻译成Java MQL 中的查询如下所示 db
  • Java,将 null 分配给对象和仅声明之间有什么区别

    之间有什么区别 Object o null and Object o 仅声明 有人可以回答我吗 这取决于您声明变量的范围 例如 局部变量没有default values在这种情况下你将不得不分配null手动 在这种情况下实例变量分配 nul
  • 适用于 Solaris 的 Java 8 中缺少 javaws

    看起来 Oracle 从 Java 8 for Solaris 中删除了 Java Web Start javaws 在 Java 8u51 中不再可用 来自兼容性指南 http www oracle com technetwork jav
  • 在java.util中获取错误ArrayList不带参数[重复]

    这个问题在这里已经有答案了 我已经创建了一个类 Student 现在我尝试将我的 Student 对象存储在 ArrayList 中 但在编译 ArrayList 不接受参数时出现错误 我已经检查了我的代码很多次 但找不到问题所在 我的学生
  • 在Java中使用BufferedWriter写入文件时监视文件大小?

    我正在将一个可能很长的项目列表写入文件 我正在写的项目的长度是可变的 如果生成的文件大小大于10M 则应将其分成多个文件 为了提高性能 我目前使用 BufferedWriter 如下所示 final FileOutputStream fos
  • perl 和 java 正则表达式功能之间有什么区别?

    perl 和 java 在支持哪些正则表达式术语方面有什么区别 这个问题仅涉及正则表达式 并且特别排除了how可以使用正则表达式 即使用正则表达式的可用函数 方法 以及语言之间的语法差异 例如java要求转义反斜杠等 特别令人感兴趣的是 j
  • Java中的OR运算(BitSet.class)

    如何编写一个程序 该程序需要001010101110000100100 011100010001000011000 000000000010000000000100 作为输入 位 输出将是OR其中 3 个 OR 0 0 0 0 1 1 1
  • 使用 Java 通过 HTTP 下载未知长度的文件

    我想用java下载一个HTTP查询 但是我下载的文件在下载时有一个未确定的长度 我认为这将是相当标准的 所以我搜索并找到了它的代码片段 http snipplr com view 33805 http snipplr com view 33
  • 使用 include 进行 JAXB 剧集编译不起作用

    我有 2 个模式 A B 我在 B 中重用了一些 A 元素 我不使用命名空间 我在用着
  • 如何将列表中的每个项目转换为字符串,以便连接它们? [复制]

    这个问题在这里已经有答案了 我需要加入一个项目列表 列表中的许多项目都是从函数返回的整数值 IE myList append munfunc 我应该如何将返回的结果转换为字符串以便将其加入列表 我是否需要对每个整数值执行以下操作 myLis
  • java Runtime.getRunTime().exec 和通配符?

    我正在尝试使用删除垃圾文件 Process p Runtime getRuntime exec 只要我不使用通配符 它 就可以正常工作 即 Process p Runtime getRuntime exec bin rm f specifi
  • 将变量从 jenkins 传递到 testng.xml

    我想根据从詹金斯传递的变量运行测试用例 例如 选择您要运行的测试用例 测试用例一 测试用例二 在 pom xml maven 中
  • Apache HttpClient TCP Keep-Alive(套接字保持活动)

    我的 http 请求需要太多时间才能被服务器处理 大约 5 分钟 由于连接闲置 5 分钟 代理服务器将关闭连接 我正在尝试在 Apache DefaultHttpClient 中使用 TCP Keep Alive 来使连接长时间处于活动状态
  • 如何修改生成的SOAP请求?

    我正处于创建输出拦截器并从 SOAP 消息中获取 OuputStream 的阶段 但是 如何在将 SOAP 信封发送到端点之前对其进行修改呢 我想删除一些 xml 元素 一种方法是获取文档并通过 XSLT 转换运行它 您可以通过调用来获取拦
  • R 中的整数或双精度列表

    我有一个大约 1000 个整数的列表 我需要能够进行一些数学计算 但它们被困在列表或字符形式中 我怎样才能切换它们以便它们可用 样本数据 gt y 1 1 7 3 1 6 7 1 7 6 5 3 1 3 3 0 6 2 4 9 19 1 9
  • JSP 和 scriptlet

    我知道现在使用 scriptlet 被认为是禁忌 没关系 我会同意Top Star的话 因为我目前只是Java新手 到目前为止我听到的是 它是为了让设计师的生活更轻松 但我想知道 这是否与JSP页面的性能有关 另一方面 如果只是为了 让设计
  • 如何隐藏或删除 Android HoneyComb 中的状态栏?

    如何隐藏或删除 Android HoneyComb 中的状态栏 每次运行应用程序时 我都会发现某些内容必须被状态栏覆盖 我尝试改变AndroidManifest xml 但没有任何改变 你不知道 它被认为是永久的屏幕装饰 就像电容式主页 菜
  • 升级到 Tomcat 8 时出现 ClassNotFoundException

    我最近将 NetBeans IDE 从 v7 3 升级到 v8 突然我的应用程序在连接到数据库时在服务器启动时抛出异常 这两个版本的 IDE 之间的唯一区别是后者使用 Tomcat 8 异常日志 javax naming NamingExc
  • 线程“main”中出现异常 java.lang.UnsatisfiedLinkError: ... \jzmq.dll: 找不到依赖库

    我有一个使用 ZMQ 的 java 应用程序 我已经能够在我的 Win7 PC 上运行它 我将 jzmq dll 放在 jar 可执行文件所在的同一文件夹中 然后通过命令 java jar myapp jar 运行它 我的下一步是将其移至服

随机推荐

  • 写出你所知道的测试工具,并写出他们的用途和优缺点

    写出你所知道的测试工具 并写出他们的用途和优缺点 Jmeter Apache JMeter是Apache组织开发的基于Java的压力测试工具 Apache jmeter 可以用于对静态的和动态的资源 文件 Servlet Perl脚本 ja
  • XXL-JOB详细说明

    XXL JOB 常见任务调度 单机 Timer ExectorService spring scheduled 分布式 xxl job quartz elastic job 原生定时任务的先天缺陷 XXL JOB简介 由调度中心和执行器组成
  • fabric环境

    1 1环境配置链接 https www jianshu com p 6ef2e8425087 https studygolang com articles 17546 Fabric chaincode测试 开发者模式和单元测试 https
  • 计算机网络 传输层的作用,端口,UDP协议,其他传输层协议

    传输层的作用 传输层定义 IP首部中有一个协议字段 用来标识网络层 IP 的 上一层所采用的是哪一种传输层协议 根据这个字段的协议号 就可以识别IP传 输的数据部分究竟是TCP的内容 还是UDP的内容 同样 传输层的TCP和UDP 为了识别
  • 参与 2023 第一季度官方 Flutter 开发者调查

    Flutter 3 7 已经正式发布 每个季度一次的 Flutter 开发者调查也如约而至 邀请社区的各位成员们填写 调查表链接 https flutter cn urls 2023q1wx 本次调研将会涉及既有的对 Flutter 整体和
  • 【李宏毅深度强化学习笔记】—7、Sparse Reward

    原文链接 https blog csdn net ACL lihan article details 104103873 李宏毅深度强化学习笔记 1 策略梯度方法 Policy Gradient 李宏毅深度强化学习笔记 2 Proximal
  • 24个K8S常用场景使用命令(推荐收藏)!

    kubectl是K8S中的一个命令行工具 主要用于管理和操作K8S集群 kubectl通过向K8S API发送REST请求 允许用户与K8S集群中的各种资源进行交互 列如Pod service Deployment等 kubectl提供了一
  • 【数据结构学习笔记】18:线段树(建树、单点修改、区间查询)

    1 线段树上的操作 push up int u 由子节点的信息去计算父节点的信息 例如两个子节点的区间和 加起来就是父节点表示的区间和 其中u是当前节点编号 表示用u的左右两个子节点来算一下自己这个节点的信息 push down 将父节点的
  • 数据爆炸,Python一键获取阿里法拍的爆款商品数据,并保存到数据库!

    目录 前言 获取数据代码实现 步骤1 获取目标网址 步骤2 向目标网址发送请求并获取响应内容 步骤3 解析网页内容并提取商品信息 步骤4 将商品信息保存到DataFrame中 将商品信息保存到数据库中 步骤1 安装MySQL Connect
  • Spring Boot的自动配置与自定义配置(附配置优先级表)

    相比于Spring MVC Spring Boot省去了繁琐的配置 提供了大部分场景下的默认配置 用户可以在不做任何配置的情况下使用Spring Boot框架进行开发 如果默认的参数并不能满足用户的需求 也只需创建一个配置文件并加上自定义的
  • JetBrains Rider 连接MySQL失败 解决方案

    JetBrains Rider 连接MySQL失败 解决方案 解决JetBrains Rider连接数据库失败 解决方案 设置MySQL时区 time zone 错误界面 Rider 连接mysql 用户名 密码 Port 全都配置好了 点
  • _萌新 web3

  • QFile清空原来文件内容的方法

    QFile清空原来文件内容的方法 Qt 清空文件方法 Qt 清空文件方法 方法一 void DataOperate clearFileInfos QString fileName QFile file fileName file resiz
  • LeetCode1823.找出游戏的胜利者

    共有 n 名小伙伴一起做游戏 小伙伴们围成一圈 按 顺时针顺序 从 1 到 n 编号 确切地说 从第 i 名小伙伴顺时针移动一位会到达第 i 1 名小伙伴的位置 其中 1 lt i lt n 从第 n 名小伙伴顺时针移动一位会回到第 1 名
  • 机器学习之加州房价预测(一)

    加州房价预测实例 任务 基于加州房价数据集建立一个预测模型 使之可以在给定的条件下 预测加州任何地点的房价的中位数 一 定义问题 1 公司要如何利用我的模型 模型的输出将作为另一个机器学习算法的输入 该算法在综合考虑其他因素之后 决定是否值
  • 推荐一本书——《The Scientist and Engineer's Guide to Digital Signal Processing》

    突然在国外的网站上看到一本非常好的数字信号处理的书籍 讲解简介明白 清晰易懂 书籍为免费电子版 地址为 http www dspguide com pdfbook htm
  • day05-编程题

    知识点 方法 题目1 训练 定义一个方法 该方法能够找出两个小数中的较小值并返回 在主方法中调用方法进行测试 训练提示 根据方法的功能描述 方法的参数应该是两个小数 要返回两个小数的较小值 所以返回值类型也是小数类型 解题方案 操作步骤 定
  • QT中学习Opengl---(GLSL简单的使用)

    前言 本文的代码是 LearnOpenGL 中对应代码 这里提供学习 大家喜欢的可去官方网站去看看 https learnopengl cn readthedocs io zh latest https learnopengl cn rea
  • C++的模板特例化template<>

    C 的模板特例化是指当我们定义了一个通用的模板类或模板函数时 如果特定输入参数类型或值需要进行不同的处理 我们可以为这些特定情况提供单独的实现 这就是模板特例化 下面我们将详细介绍C 的模板特例化 假设我们有以下的一个模板类 templat
  • java自学笔记12:java中的集合框架(下)List

    一 学生选课 判断List中课程是否存在 思考 在课程序列中 如何判断是否包含某门或者某几门课程 如果课程序列包含某门课程 如何判断该课程的索引位置 在学生映射表中 如何判断是否包含某个学生ID 又该如何判断是否包含某个学生对象 如果想把课