当前位置: 首页 > article >正文

B站宋红康JAVA基础视频教程之Chapter13(泛型)

文章目录

      • 1.为什么需要泛型
      • 2.泛型的使用案例
      • 3.自定义泛型方法
      • 4.有限制条件的通配符的使用

1.为什么需要泛型

1.如下:test01中集合中添加元素,不限制类型,字符串的我也能加入,数字的我也能加入,那么我想对集合中做一个取最大值操作时,就会出现异常,那么如何才能避免这个错误呢?我们可以给类一个标识,标识这个参数的类型

泛型在ArrayList中的使用

public class CollectionMapTest {
    @Test
    public void test() {
        List list = new ArrayList(); // ArrayList实现了List接口
        list.add(67);
        list.add(68);
        list.add(69);
        list.add(70);
        // 1.问题1:类型不安全,因为add()的参数是Object类型,因为着任何类型的对象都可以添加成功
//        list.add("AA");
        Iterator iterator = list.iterator();

        while (iterator.hasNext()) {
            // 问题2:强转可能出现问题
            Integer i = (Integer)iterator.next();
            int score = i;

        }

    }

    @Test
    public void test2() {
       List<Integer> list =  new ArrayList<>();
       list.add(32);
       list.add(33);
       list.add(34);
       list.add(35);

       Iterator<Integer> iterator = list.iterator();
       while (iterator.hasNext()) {
           Integer i = iterator.next();
           int score = i;

           System.out.println(score);
       }
    }
}

泛型在Map中的使用

@Test
    public void test3() {
        HashMap<String, Integer> map = new HashMap<String, Integer>();

        map.put("Tom", 12);
        map.put("Jerry", 15);

        //Set<Map.Entry<String, Integer>> entries = map.entrySet();

        //Iterator<Map.Entry<String, Integer>> iterator = entries.iterator();
		// 上面两行的简写方式如下
		var entries = map.entrySet();

        var iterator = entries.iterator();

        while(iterator.hasNext()) {
            Map.Entry<String, Integer> entry = iterator.next();
            String key = entry.getKey();
            Integer value = entry.getValue();
            System.out.println(key + "____" + value);
        }
    }

2.泛型的使用案例

1.自然排序和定制排序的使用
2.注意:TreeSet添加元素的时候需要保证是同一个类型的元素,否则会报错
3.静态方法中无法使用泛型
4.自定义异常类无法使用泛型

public class EmployeeTest {
    public static void main(String[] args) {
        TreeSet<Employee> set = new TreeSet<>();

        Employee e1 = new Employee("LiLei", 18, new MyDate(1998, 12,28));
        Employee e2 = new Employee("HanMei", 23, new MyDate(2001, 12,28));
        Employee e3 = new Employee("ASh", 14, new MyDate(2006, 12,28));
        Employee e4 = new Employee("sasa", 32, new MyDate(2003, 12,28));
        set.add(e1);
        set.add(e2);
        set.add(e3);
        set.add(e4);

        Iterator<Employee> iterator = set.iterator();

        // 1.自然排序
        while (iterator.hasNext()) {
            Employee employee = iterator.next();
            System.out.println(employee);
        }

        System.out.println("---------------------------分割线-------------------------------");


        // 2.按照生日排序(这里的实现方式是匿名内部类,实现了Comparator接口,并定制排序)
        Comparator<Employee> comparator = new Comparator<Employee>(){
            @Override
            public int compare(Employee o1, Employee o2) {
                int yeardistance = o1.getBirthday().getYear() - o2.getBirthday().getYear();
                if (yeardistance != 0) {
                    return yeardistance;
                }
                int monthdistance = o1.getBirthday().getMonth() - o2.getBirthday().getMonth();
                if (monthdistance != 0) {
                    return monthdistance;
                }
                return o1.getBirthday().getDay() - o2.getBirthday().getDay();
            }
        };
        TreeSet<Employee> set1 = new TreeSet<>(comparator);

        Employee e11 = new Employee("LiLei", 18, new MyDate(1998, 12,28));
        Employee e22 = new Employee("HanMei", 23, new MyDate(2001, 12,28));
        Employee e33 = new Employee("ASh", 14, new MyDate(2006, 12,28));
        Employee e44 = new Employee("sasa", 32, new MyDate(2003, 12,28));
        set1.add(e11);
        set1.add(e22);
        set1.add(e33);
        set1.add(e44);

        Iterator<Employee> iterator2 = set1.iterator();


        while (iterator2.hasNext()) {
            Employee employee = iterator2.next();
            System.out.println(employee);
        }

    }
}

3.自定义泛型方法

形式

权限修饰符 返回值类型 方法名(形参列表) {
// 通常形参列表和返回值类型的位置会出现泛型参数T
}

泛型方法可以根据需要确定是否加static
泛型方法所属的类是否是一个泛型类(没有关系)

public <E> E method(E e) {
	return null;
}

4.有限制条件的通配符的使用

  • List<? extends A>: 可以将List<-A-> 或 List<-B->赋值给它,B必须是A的子类
  • List<? super A>: 可以将List<-A-> 或 List<-B->赋值给它,B必须是A的父类

http://www.kler.cn/a/299873.html

相关文章:

  • WebForms 表单
  • HTML常见文本标签解析:从基础到进阶的全面指南
  • Ansible入门学习之基础元素介绍
  • Pyecharts之图表组合与布局优化
  • 数据库SQLite和SCADA DIAView应用教程
  • 16.好数python解法——2024年省赛蓝桥杯真题
  • Inspector里面可以编辑的变量相关
  • C#使用handle实现获取占用指定文件或文件夹的进程(Locksmith功能)
  • Linux编译器-gcc/g++使用
  • java后端如何发送httpGET和POST请求
  • .NET 一款用于解密web.config配置的工具
  • 11.5.软件系统分析与设计-面向对象的程序设计与实现
  • 【贪心算法】(一)贪心算法理论及基础习题
  • Redis:发布(pub)与订阅(sub)实战
  • HBase 源码阅读(四)HBase 关于LSM Tree的实现- MemStore
  • 视频怎么转换成mp3格式?分享5种便捷的转换方法
  • Ef 在迁移过程中 遇到 The migration ‘xxxx‘ was not found. 的问题(未解决)
  • JAVAEE初阶第七节(下)——物理原理与TCP_IP
  • 代码随想录训练营day44|1143.最长公共子序列,1035.不相交的线, 53. 最大子序和,392.判断子序列
  • TinyWebserver的复现与改进(7):日志系统
  • 25 考研数学大纲有什么变化?
  • 果蔬识别系统性能优化之路(一)
  • 【LeetCode:3174】清除数字(Java)
  • 《JavaEE进阶》----15.<Spring Boot 日志>
  • Day 31: 贪心算法基础 V
  • 【linux-Day2】linux下的基本指令