泛型的使用与通配符

2023-05-16

文章目录

    • 泛型的使用
      • 1.jdk1.5新特性泛型
      • 2.为什么要使用泛型?
      • 3.在集合中使用泛型
    • 自定义泛型结构:泛型类,泛型接口;泛型方法
        • 泛型类被某个类继承
        • 自定义泛型的注意点
        • 泛型方法
      • 泛型在继承方面的体现
      • 通配符的使用
      • 有限制条件的通配符的使用。


文章链接
Java语法https://blog.csdn.net/weixin_45606067/article/details/107049186
一维数组与二维数组、内存解析https://blog.csdn.net/weixin_45606067/article/details/107049178
面向对象(1/3)类和对象https://blog.csdn.net/weixin_45606067/article/details/108234276
面向对象(2/3)封装性、继承性、多态性https://blog.csdn.net/weixin_45606067/article/details/108234328
面向对象(3/3)抽象类、接口、内部类、代码块https://blog.csdn.net/weixin_45606067/article/details/108258152
异常处理待更新
多线程(1/2)https://blog.csdn.net/weixin_45606067/article/details/107067785
多线程(2/2)https://blog.csdn.net/weixin_45606067/article/details/107067857
常用类https://blog.csdn.net/weixin_45606067/article/details/108283203
枚举与注解待更新
集合(1/5)Collection、Iterator、增强forhttps://blog.csdn.net/weixin_45606067/article/details/107046876
集合(2/5)List、ArrayList、LinkedList、Vector的底层源码https://blog.csdn.net/weixin_45606067/article/details/107069742
集合(3/5)set、HashSet、LinkedHashSet、TreeSet的底层源码
集合(4/5)Map、HashMap底层原理分析https://blog.csdn.net/weixin_45606067/article/details/107042949
集合(5/5)LinkHashMap、TreeMap、Properties、Collections工具类https://blog.csdn.net/weixin_45606067/article/details/107069691
泛型与Filehttps://blog.csdn.net/weixin_45606067/article/details/107124099
IO流与网络编程https://blog.csdn.net/weixin_45606067/article/details/107143670
反射机制待更新
Java8新特性https://blog.csdn.net/weixin_45606067/article/details/107280823
Java9/10/11新特性待更新

泛型的使用

1.jdk1.5新特性泛型

把元素的类型设计成一个参数,这个参数类型叫做泛型。

2.为什么要使用泛型?

  • 类型无限制,类型不安全。
  • 类型强制转换时,容易出现异常。ClassCastException

3.在集合中使用泛型

  • 集合接口或类在jdk5.0时都修改为带泛型的结构。
  • 在实例化集合类时,可以指明具体的泛型类型。
  • 指明完以后,在集合类或接口中凡是定义接口或类时,内部结构使用到类的泛型位置,都指定为实例化的泛型。
  • 泛型的类型必须是一个类。使用基本数据类型时,需要转换为包装类。
  • 如果实例化时,没有指明泛型的类型,默认为Object类型。
  • 如果泛型结构是一个接口或抽象类,则不能创建泛型类的对象。
  • jdk1.7 泛型的简化操作:
ArrayList<Integer> list = new ArrayList<>();
  • 泛型类可以有多个参数,此时应将多个参数一起放在尖括号内。比如:<E1,E2,E3>

代码举例:

public class GenericTest {

    @Test
    public void test1(){
        //在集合中使用泛型的情况:以ArrayList为例
//        ArrayList<Integer> list = new ArrayList<Integer>();
        //jdk7新特性:类型推断
        ArrayList<Integer> list = new ArrayList<>();
        list.add(99);
        list.add(100);
        list.add(88);
        //方式一:
        for (Integer integer:list){
            System.out.print(integer+" ");
        }
        System.out.println();
        //方式二:
        Iterator<Integer> iterator = list.iterator();
        while (iterator.hasNext()){
            System.out.print(iterator.next()+" ");
        }
        System.out.println();
        
        //在集合中使用泛型的情况:以ArrayList为例
        HashMap<String, Integer> map = new HashMap<String, Integer>();
        map.put("Tom",123);
        map.put("Jerry",456);
        map.put("Jack",789);
        Set<Map.Entry<String, Integer>> set = map.entrySet();
        Iterator<Map.Entry<String, Integer>> iterator1 = set.iterator();
        while (iterator1.hasNext()){
            //System.out.print(iterator1.next()+" ");
            Map.Entry<String, Integer> ee = iterator1.next();
            String key = ee.getKey();
            Integer value = ee.getValue();
            System.out.println(key + ":"+value);
        }
    }
}

自定义泛型结构:泛型类,泛型接口;泛型方法

泛型类被某个类继承

①public class SubOrder extends Order//此时子类时普通类
由于子类在继承带泛型的父类时,指明了泛型类型,则实例化子类对象时,不再需要指明泛型。
②public class SubOrder1 extends Order//此时子类也是泛型类

自定义泛型的注意点

①泛型不同的引用不能相互赋值

ArrayList<Integer>list1=null;
ArrayList<String>list2=null;

此时list1和list2不能相互赋值。

②类型推断

Order<String> order1 = new Order<>();

③静态方法中不能使用类的泛型。

④异常类不能是泛型的。

⑤不能使用new E[]。但是可以:E[] elements = (E[]) new Object[];

代码举例:

//自定义泛型类
public class Order<T> {
    String orderName;
    Integer orderId;

    //类的内部结构就可以使用类的泛型
    T orderT;

    public Order(){

    }

    public Order(String orderName, Integer orderId, T orderT) {
        this.orderName = orderName;
        this.orderId = orderId;
        this.orderT = orderT;
    }

    public T getOrderT() {
        return orderT;
    }

    public void setOrderT(T orderT) {
        this.orderT = orderT;
    }

    @Override
    public String toString() {
        return "Order{" +
                "orderName='" + orderName + '\'' +
                ", orderId=" + orderId +
                ", orderT=" + orderT +
                '}';
    }
}


//测试自定义泛型类
@Test
public void test1(){
  //如果定义了泛型类,实例化没指明类的泛型,则认为此泛型类型为Object类型。
  //若果定义了类是泛型类的,建议实例化时要指明类的泛型。
  Order order=new Order();
  order.setOrderT(123);
  order.setOrderT("abc");

  Order<String> order1 = new Order<String>("orderAA",23,"order:AA");
  order1.setOrderT("AA:hello");
}

泛型方法

在方法中出现了泛型的结构,泛型参数与类的泛型参数没有任何关系。
换句话说,泛型方法所属的类是不是泛型类都没有关系。
泛型方法可以声明为静态的。原因:泛型参数是在调用方法时确定的。并非在实例化类时确定。

public static <E> List<E> copyFromArrayToList(E[] arr){
    ArrayList<E> list = new ArrayList<>();
    for(E e : arr){
        list.add(e);
    }
    return list;
}


//测试泛型方法
@Test
public void test4(){
  Order<String> order = new Order<>();
  Integer[] arr = new Integer[]{1,2,3,4};
  //泛型方法在调用时,指明泛型参数的类型。
  List<Integer> list = order.copyFromArrayToList(arr);

  System.out.println(list);
}

泛型在继承方面的体现

/*
虽然类A是类B的父类,但是G<A> 和G<B>二者不具备子父类关系,二者是并列关系。
补充:类A是类B的父类,A<G> 是 B<G> 的父类
*/
@Test
public void test1(){
    Object obj = null;
    String str = null;
    obj = str;

    Object[] arr1 = null;
    String[] arr2 = null;
    arr1 = arr2;
    //编译不通过
//        Date date = new Date();
//        str = date;
    List<Object> list1 = null;
    List<String> list2 = new ArrayList<String>();
    //此时的list1和list2的类型不具有子父类关系
    //编译不通过
//        list1 = list2;
    /*
    反证法:
    假设list1 = list2;
       list1.add(123);导致混入非String的数据。出错。

     */

    show(list1);
    show1(list2);
}
public void show1(List<String> list){}
public void show(List<Object> list){}

通配符的使用

/*
通配符:?
类A是类B的父类,G<A>和G<B>是没有关系的,二者共同的父类是:G<?>
*/
@Test
    public void test3(){
        List<Object> list1 = null;
        List<String> list2 = null;

        List<?> list = null;

        list = list1;
        list = list2;
        //编译通过
//        print(list1);
//        print(list2);

        List<String> list3 = new ArrayList<>();
        list3.add("AA");
        list3.add("BB");
        list3.add("CC");
        list = list3;
        //添加(写入):对于List<?>就不能向其内部添加数据。
        //除了添加null之外。
//        list.add("DD");
//        list.add('?');

        list.add(null);

        //获取(读取):允许读取数据,读取的数据类型为Object。
        Object o = list.get(0);
        System.out.println(o);
    }

    public void print(List<?> list){
        Iterator<?> iterator = list.iterator();
        while(iterator.hasNext()){
            Object obj = iterator.next();
            System.out.println(obj);
        }
    }

有限制条件的通配符的使用。

/*
? extends A:
        G<? extends A> 可以作为G<A>和G<B>的父类,其中B是A的子类

? super A:
        G<? super A> 可以作为G<A>和G<B>的父类,其中B是A的父类
*/
@Test
    public void test4(){

        List<? extends Person> list1 = null;
        List<? super Person> list2 = null;

        List<Student> list3 = new ArrayList<Student>();
        List<Person> list4 = new ArrayList<Person>();
        List<Object> list5 = new ArrayList<Object>();

        list1 = list3;
        list1 = list4;
//        list1 = list5;

//        list2 = list3;
        list2 = list4;
        list2 = list5;

        //读取数据:
        list1 = list3;
        Person p = list1.get(0);
        //编译不通过
        //Student s = list1.get(0);

        list2 = list4;
        Object obj = list2.get(0);
        编译不通过
//        Person obj = list2.get(0);

        //写入数据:
        //编译不通过
//        list1.add(new Student());

        //编译通过
        list2.add(new Person());
        list2.add(new Student());

    }

如果有收获!!! 希望老铁们来个三连,点赞、收藏、转发
创作不易,别忘点个赞,可以让更多的人看到这篇文章,顺便鼓励我写出更好的博客
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

泛型的使用与通配符 的相关文章

  • Java小型计算器

    通过对程序的编写 xff0c 可以不同位数实现对加减乘除的计算 xff0c 以及对错误答案给出提示 以满足一些大人给小孩出题的困惑 xff0c 此程序可以自己出题 xff0c 自己检测答案 随时随地想做就做 需求 xff1a 1 实现计算器
  • 杨辉三角 | 回形数 | 复制 | 赋值练习题

    目录 杨辉三角回形数格式方阵的实现使用简单数组拓展 xff1a 修改题目 xff0c 实现array2对array1数组的复制 杨辉三角 使用二维数组打印一个10行杨辉三角 span class token keyword public s
  • 水仙花数 | 平闰年 | 斐波那契数列 | 反转单词

    目录 水仙花1 三位数的水仙花2 四位数的水仙花 平闰年斐波那契数列反转句子中单词顺序 水仙花 1 三位数的水仙花 span class token keyword for span span class token punctuation
  • 图像去雾:AOD-Net

    论文地址 xff1a https arxiv org pdf 1707 06543 pdf 相关代码 xff1a GitHub MayankSingal PyTorch Image Dehazing PyTorch implementati
  • 打印三角形 | 所有素数

    目录 3 100的所有素数找出来5 5正方形直角三角形反直角三角形正等腰三角形 xff08 金字塔 xff09 倒立等腰三角形 4 61 1 1 1 3 43 1 5 1 7 43 1 9 1 11 43 43 1 n 若n为99 3 10
  • 冒泡排序 | 快速排序 | 线性查找 | 二分查找等

    目录 排序算法 xff1a 冒泡排序排序算法 xff1a 快速排序数组的复制 反转 查询 xff08 线性查找 二分查找 xff09 排序算法 xff1a 冒泡排序 span class token keyword public span
  • 多线程(1/2)

    文章目录 一 多线程概述1 概念1 1 程序 进程 线程1 2 单核cpu和多核cpu1 3 并行和并发 2 优点3 何时需要 二 继承Thread类1 多线程创建的方式一 xff1a 继承于Thread类2 线程常用方法3 线程的优先级4
  • 多线程(2/2)

    文章目录 一 程序安全的单例模式之懒汉式1 通过同步代码块解决懒汉式单例设计模式的线程安全问题2 通过同步方法解决懒汉式单例设计模式的线程安全问题 二 死锁问题1 死锁的理解 2 说明 三 Lock锁方式解决线程安全问题四 线程的通信1 涉
  • 集合框架(5):LinkHashMap | TreeMap | Properties | Collections工具类

    文章目录 一 LinkedHashMap底层实现原理二 TreeMap1 自然排序2 定制排序 三 Properties四 Collections 工具类1 工具类中常用的方法2 代码演示 文章链接Java语法https blog csdn
  • 集合框架(2):List | ArrayList | LinkedList | Vector的底层源码

    文章目录 一 list比较ArrayList LinkedList Vector三者的异同 xff1f List接口常用方法List遍历及常用方法总结 ArrayList源码分析LinkedList源码分析Vector源码分析ArrayLi
  • 集合框架(3):set | HashSet | LinkedHashSet | TreeSet的底层源码

    文章目录 一 Set练习题 xff1a 在list内去除重复数据值 二 HashSet三 LinkHashSet四 TreeSet1 自然排序2 定制排序 文章链接Java语法https blog csdn net weixin 45606
  • 单例设计模式

    目录 一 设计模式1 理解2 常用设计模式 23种经典的设计模式 二 单例设计模式1 概念 xff1a 2 如何实现 xff1f 3 饿汉式和懒汉式的区别4 应用场景 xff1a 三 模板方法的设计模式1 解决的问题2 举例3 应用场景 一
  • PageHelper实现分页详细版、整合SSM应用

    在项目开发中我们经常要实现分页技术 xff0c 传统的开发过于繁琐 xff0c 这里我们讲解MyBatis中引进的PageHelper实现分页 简单易懂 xff0c 便于上手 xff01 xff01 xff01 参照官网 完成以下分页技术的
  • 最详细IDEA 的安装、配置与使用

    目录 IDEA 的安装 配置与使用一 IntelliJ IDEA 介绍1 IntelliJ IDEA 介绍2 官网 xff1a 3 IDEA 的下载地址 xff1a 官网 4 官网提供的详细使用文档 xff1a 二 windows 下载安装
  • 对遗传算法(GA)的一些理解

    目录 1 遗传算法的原理 2 遗传算法的主要流程 3 对遗传算法中的选择 编码 交叉及变异的理解 1 遗传算法的原理 基因以染色体为载体在种群间得以传播 xff0c 而基因在相当程度上决定了个体的表现型 性状 xff0c 这个传播过程常常伴
  • 最详细IDEA 常用配置、布局说明

    目录 一 创建 Java 工程 xff0c 分析页面布局1 设置显示常见的视图2 工程界面展示3 查看项目配置 二 常用配置 以idea 2019为例 1 设置主题2 设置字体大小 xff08 1 xff09 非代码窗口设置UI样式和字体
  • Springboot整合阿里云短信服务

    文章目录 开通阿里云了解阿里云用户权限操作开通阿里云短信服务添加短信模板添加签名 Springboot整合短信到项目中1 创建一个SpringBoot的项目2 导入依赖3 配置文件4 主启动类5 工具类6 控制器7 业务层8 测试 最好有S
  • 使用JS实现表单验证

    目录 表单页面展示FormCheck jsp CSS样式Register css JavaScript代码FormCheck js 效果图展示 平时我们在注册账号的时候经常看到有提示xxx不得法 xff0c 请重新填写字样 xff0c 本文
  • 对Spring深入的理解 | 概念的总结

    一 Spring的概述 官网 xff1a https spring io projects spring framework overview 官方下载地址 xff1a https docs spring io spring docs 4

随机推荐

  • Spring AOP详解

    1 简述 AOP 概念 AOP xff1a Aspect Oriented Program xff0c 面向 方面 切面的编程 xff1b Filter 过滤器 也是一种 AOP AOP 是一种新的方法论 xff0c 是对传统 OOP Ob
  • Spring IOC详解

    一 IOC的基本概念 1 简述 IOC 概念 IOC Invert Of Control xff0c 控制反转 也成为 DI 依赖注入 其思想是反转资源获取的方向 传统的资源查找方式要求组件向容器发起请求查找资源 作为回应 容器适时的返回资
  • Spring 声明式事务

    文章目录 1 回顾事务2 spring的事务管理3 Spring事务的种类4 基于XML的事务配置1 使用说明2 代码如下 5 基于注解的事务配置1 使用说明2 代码如下 6 基于XML和注解的事务配置代码如下 7 64 Transacti
  • Spring 依赖注入详解

    一 IOC 依赖注入 1 什么是Spring的依赖注入 依赖注入 xff0c 是IOC的一个方面 xff0c 是个通常的概念 xff0c 它有多种解释 这概念是说你不用创建对象 xff0c 而只需要描述它如何被创建 你不在代码里直接组装你的
  • JDBC(1) API详细说明

    目录 一 JDBC概述1 什么是 JDBC2 JDBC API3 JDBC 程序编写步骤 二 用使用 JDBC API1 引入 JDBC 驱动程序1 1 如何获取 JDBC 驱动程序1 2 在Java Project 项目应用中添加数据库驱
  • JDBC(2) 工具类 | PreparedStatement详细说明

    目录 一 JDBC 工具类使用 JDBC API 操作数据库的基本步骤编写工具类 JDBCUtils 二 PreparedStatement1 PreparedStatement 概述2 Statement 的不足3 PreparedSta
  • python: image.paste函数的理解

    目录 image paste函数 举例说明 xff1a image paste函数 python中PIL库中的paste函数的作用为将一张图片覆盖到另一张图片的指定位置去 函数的声明如下 xff1a def paste self im bo
  • JDBC(3)实现通用的增删改查方法

    编写通用的增删改查方法 不明白的可以看代码中注释 xff0c 写的很详细 1 通用的增删改 span class token comment 通用的更新数据库的方法 xff1a insert update delete 语句时 span s
  • JDBC(4)DBCP数据源 | C3P0 数据源

    1 DBCP 数据源 DBCP 是 Apache 软件基金组织下的开源连接池实现 xff0c 该连接池依赖该组织下的另一个开源系统 xff1a Common pool 如需使用该连接池实现 xff0c 应在系统中增加如下两个 jar 文件
  • JDBC(5)DBUtils类详解

    1 DbUtils 类 DbUtils xff1a 提供如关闭连接 装载 JDBC 驱动程序等常规工作的工具类 xff0c 里面的所有方法都是静态的 主要方法如下 xff1a public static void close throws
  • 验证码实现 - html页面版

    前言 图片验证码是我们日常经常用到的 xff0c 本文将介绍如何实现以及其原理 xff0c 并没有过多注重css样式 xff0c 单纯实现验证码功能 如果对滑块验证码感兴趣的可以看这篇文章 xff1a 滑块验证码实现及原理 如果对验证码实现
  • 验证码实现 - 工具类调用版

    前言 图片验证码是我们日常经常用到的 xff0c 本文将介绍如何实现以及其原理 xff0c 以注册页面为例实现功能 如果对滑块验证码感兴趣的可以看这篇文章 xff1a 滑块验证码实现及原理 如果对验证码实现感兴趣的可以看这篇文章 xff1a
  • 滑块验证码实现

    前言 滑块验证码也是生活中常见的 xff0c 本文会介绍如何实现以及原理 如果对验证码实现感兴趣的可以看这篇文章 xff1a 验证码实现 html页面版 如果对验证码实现感兴趣的可以看这篇文章 xff1a 验证码实现 工具类调用版 代码实现
  • MySQL(1)的使用 | SQL

    目录 MySQL 的使用1 启动和停止服务方式一 xff1a 图形化方式方式二 xff1a 命令行 2 客户端登录方式一 xff1a MySQL 自带客户端方式二 xff1a 命令行方式三 xff1a 可视化工具 SQL1 SQL 的语言规
  • MySQL(2)DDL详解

    一 DDL 1 1 操作 Database 注意 xff1a database 不能改名 一些可视化工具可以改名 xff0c 它是建新库 xff0c 把所有表复制到新库 xff0c 再删旧库完成的 1 创建数据库 create databa
  • MySQL(4)运算符 | 关联查询详解

    一 MySQL 的运算符 xff08 1 xff09 算术运算符 xff1a 43 xff08 除也可以写成 div xff08 取模可以写成 mod xff09 xff08 2 xff09 比较运算符 xff1a 61 gt gt 61
  • MySQL(5)条件查询 | 单行函数 | 事务详解

    一 select 的 的 5 个子句 1 where 条件查询 从原表中的记录中进行筛选 2 group by 分组查询 很多情况下 xff0c 用户都需要进行一些汇总操作 xff0c 比如统计整个公司的人数或者统计每一个部门的人数等 聚合
  • python:tqdm——进度条显示操作

    在代码执行过程中 xff0c 如果想要看到代码的实时运行进度 xff0c 可以使用tqdm库来进行进度条可视化 tqdm的安装 xff1a pip install tqdm 举一个常用参数的使用例子 xff1a from tqdm impo
  • MySQL(3)DML详解

    一 DML 数据操纵语言 xff08 DML xff09 DML 用于插入 修改 删除数据记录 xff0c 包括如下 SQL 语句 xff1a INSERT xff1a 添加数据到数据库中 UPDATE xff1a 修改数据库中的数据 DE
  • 泛型的使用与通配符

    文章目录 泛型的使用1 jdk1 5新特性泛型2 为什么要使用泛型 xff1f 3 在集合中使用泛型 自定义泛型结构 xff1a 泛型类 xff0c 泛型接口 xff1b 泛型方法泛型类被某个类继承自定义泛型的注意点泛型方法 泛型在继承方面