Java泛型

本文详细探讨了Java泛型的使用,从为什么需要泛型到在集合中的应用,再到自定义泛型类、接口和方法的实现。还讨论了泛型在继承、通配符的限制以及实际应用中的各种场景,提供了丰富的示例来帮助理解。
摘要由CSDN通过智能技术生成

1.为什么要有泛型(因为不确定)

image-20220209004820248 image-20220209004842074 image-20220209004858746 image-20220209004922466
 //在集合中使用泛型之前的情况:
    @Test
    public void test1(){
   
        ArrayList list = new ArrayList();
        //需求:存放学生的成绩
        list.add(78);
        list.add(76);
        list.add(89);
        list.add(88);
        //问题一:类型不安全
//        list.add("Tom");

        for(Object score : list){
   
            //问题二:强转时,可能出现ClassCastException
            int stuScore = (Integer) score;

            System.out.println(stuScore);

        }

    }

2.在集合中使用泛型

/**
 *
 * 泛型的使用
 * 1.jdk 5.0新增的特性
 *
 * 2.在集合中使用泛型:
 *  总结:
 *  ① 集合接口或集合类在jdk5.0时都修改为带泛型的结构。
 *  ② 在实例化集合类时,可以指明具体的泛型类型
 *  ③ 指明完以后,在集合类或接口中凡是定义类或接口时,内部结构(比如:方法、构造器、属性等)使用到类的泛型的位置,都指定为实例化的泛型类型。
 *    比如:add(E e)  --->实例化以后:add(Integer e)
 *  ④ 注意点:泛型的类型必须是类,不能是基本数据类型。需要用到基本数据类型的位置,拿包装类替换
 *  ⑤ 如果实例化时,没有指明泛型的类型。默认类型为java.lang.Object类型。
 *
 * 3.如何自定义泛型结构:泛型类、泛型接口;泛型方法。见 GenericTest1.java
 *
 */

    //在集合中使用泛型的情况:以ArrayList为例
    @Test
    public void test2(){
   
       ArrayList<Integer> list =  new ArrayList<Integer>();

        list.add(78);
        list.add(87);
        list.add(99);
        list.add(65);
        //编译时,就会进行类型检查,保证数据的安全
//        list.add("Tom");

        //方式一:
//        for(Integer score : list){
   
//            //避免了强转操作
//            int stuScore = score;
//
//            System.out.println(stuScore);
//
//        }
        //方式二:
        Iterator<Integer> iterator = list.iterator();
        while(iterator.hasNext()){
   
            int stuScore = iterator.next();
            System.out.println(stuScore);
        }

    }

    //在集合中使用泛型的情况:以HashMap为例
    @Test
    public void test3(){
   
//        Map<String,Integer> map = new HashMap<String,Integer>();
        //jdk7新特性:类型推断
        Map<String,Integer> map = new HashMap<>();

        map.put("Tom",87);
        map.put("Jerry",87);
        map.put("Jack",67);

//        map.put(123,"ABC");
        //泛型的嵌套
        Set<Map.Entry<String,Integer>> entry = map.entrySet();
        Iterator<Map.Entry<String, Integer>> iterator = entry.iterator();

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

    }

3.自定义泛型结构

3.1 自定义泛型类、 自定义泛型接口
image-20220213222008396 image-20220213222048287 image-20220213222213310

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HtlzsT7P-1644820850689)(C:\Users\linyinlei\AppData\Roaming\Typora\typora-user-images\image-20220213230034058.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mZV5mMTq-1644820850690)(C:\Users\linyinlei\AppData\Roaming\Typora\typora-user-images\image-20220213230045607.png)]

1. jdk7.0后实例化时可以智能读取,后面的不用写
     Order<String> order = new Order<>();
2/3.泛型类的构造器不用泛型标识,在实例化类时需要用到就指定就行
    public class Order<T> {
   
      public Order(){
   
    
    }
  }
 Order<String> order = new Order<>();
4. 泛型不同的引用不能相互赋值。
    @Test
    public void test3(){
   

        ArrayList<String> list1 = null;
        ArrayList<Integer> list2 = new ArrayList<Integer>();
        
//        list1 = list2;
    }
5.不能用new E[],因为E,就是一个标签,不是一个类,不能实例化,继承于Object,但可以创建一个对象,把它强转成什么什么类型
     public Order(){
   
        //编译不通过
        //T[] arr = new T[10];
        //编译通过
        T[] arr = (T[]) new Object[10];
    }
6.异常类不能用泛型
 //public class MyException<T> extends Exception
 // {
   
 // }
       public void show(){
   
        //编译不通过
//        try{
   
//
//
//        }catch(T t){
   
//
//        }

    }
7.静态方法中不能使用类的泛型。因为静态最先加载,此时泛型T还没加载到
//    public static void show(T orderT){
   
//        System.out.println(orderT);
<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值