【Java】这个泛型不太正经

举报
执久呀 发表于 2022/01/14 14:40:30 2022/01/14
【摘要】 ​ 目录一、前言二、泛型三、泛型定义的格式:什么是引用类型?泛型的好处是: 四、泛型类五、泛型方法六、泛型接口七、类型通配符一、前言泛型在java中有很重要的地位,在实际开发中用处也很大。二、泛型泛型:是jdk5中引入的特性,他提供编译是类型是类型的安全检测机制,这个机制允许在编译时检测到非法的类型,它的本质是参数化类型,也就是所操作的数据类型不变指定为一个参数将原来具体的类型参数化,然后再...

 目录

一、前言

二、泛型

三、泛型定义的格式:

什么是引用类型?

泛型的好处是:

 四、泛型类

五、泛型方法

六、泛型接口

七、类型通配符


一、前言

泛型在java中有很重要的地位,在实际开发中用处也很大。

二、泛型

泛型:是jdk5中引入的特性,他提供编译是类型是类型的安全检测机制,这个机制允许在编译时检测到非法的类型,它的本质是参数化类型,也就是所操作的数据类型不变指定为一个参数

将原来具体的类型参数化,然后再使用/调用的时候传入具体的参数

泛型的类型:

①:泛型类

②:泛型方法 

③:泛型接口


三、泛型定义的格式:

<类型> :指定一种类型的格式,这里的类型可以看成是形参。

<类型1,类型2...>:指定多种类型的格式,多种类型之间用逗号隔开,这里的类型类型1,类型2可以看成是形参,将来具体调用的时候的参数看成是实参,这里的泛型只能是引用类型

什么是引用类型?

除了八大基本类型其他的都是引用类型,如基本类型对应的包装类

  • boolean -->Boolean
  • char --->Character
  • byte -->Byte
  • short -->Short
  • int -->Integer
  • long -->Long
  • float -->Float
  • double -->Double

泛型的好处是:

  •   把运行得问题提前到编译时期
  •    避免了强制转换

没指定类型默认是Object类型

举个例子,当没有使用泛型时:

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

public class 泛型Demo {
    public static void main(String[] args) {
        //创建一个对象
        Map map=new HashMap();
        //添加数据
        map.put(1, "张三");
        map.put(2, "李四");
        map.put(3,"王五");
        map.put(5, 6);//加了不一样的类型数据

        //键的集合
        Set keySet=map.keySet();
        //键找值
        for(Object key: keySet){
            String value=(String)map.get(key);
            System.out.println(key+":"+value);
        }


    }
}

报了一个类型转换异常(int会自动转化成Integer),Integer不能转为String

Exception in thread "main" java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String
 

 此时泛型的好处就体现出来了,将运行时会出现的错误拉到了编译期间。

 

 当然也可以在输出是采用Object接收

        //键的集合
        Set keySet=map.keySet();
        //键找值
        for(Object key: keySet){
           Object value=map.get(key);
          //  String value=(String)map.get(key);
            System.out.println(key+":"+value);
        }

这样也可以得到想要的结果。

 四、泛型类

泛型类的定义格式:

修饰符 class 类名<类型> { }

举例:

public class Generic<T>{}

这里的T可以使任意标识,常见的如T、E、K、V等形式常用于表示泛型。

泛型类下

public class Generic<T> {
    //定义一个变量,提供get set方法
    private T t;
    public T getT(){
        return t;
    }
    public void SetT(T t){
        this.t=t;
    }
    
}

测试类下

public class GenericDemo {
    public static void main(String[] args) {
        Generic<String> g1=new Generic<>();
        g1.SetT("章三");
        System.out.println(g1.getT());
        System.out.println("------------------");
        Generic<Integer> g2=new Generic<>();
        g2.SetT(100);
        System.out.println(g2.getT());
    }
}

运行结果

 定义这个泛型类的好处就是可以在测试中输入各种你想要的类型。

五、泛型方法

定义泛型方法的格式:

修饰符 <类型> 返回值类型 方法名 (类型 类型名)

举例:

public <T> void show (T t){}

泛型方法


public class Generic {
public <T> void show(T t){
    System.out.println(t);
}
}

泛型方法测试下:

public class GenericDemo {
    public static void main(String[] args) {
       Generic g=new Generic();
       g.show("张三");
       g.show(100);
       g.show(true);
   g.show(null);
    }
}

运行结果

 泛型方法比泛型类方便许多,直接在这使用即可,可以用个中类型的参数

六、泛型接口

格式:修饰符 interface 接口名<类型>{}

举例:

public interface Generic<T>{}

既然是接口那就得定义一个类 去实现这个接口

泛型接口:

public interface Generic<T>{
   void show();
}

 GenricImp类下:

public class GenricImp<T> implements Generic<T>{
   public void show(T t){
     System.out.println(t);   
   }
  
}

 GenricDemo类下:

public class GenricDemo{
   public static void main(String[]args){
        Generic<String> g1=new GenericImp<String>();
       g1.show("张三");
   Generic<Integer> g2=new GenericImp<Integer>();
       g2.show(100);
   }
}

七、类型通配符

<? extends T>上限通配,?表示是T的一个未知子类。


<? super T>下限通配,?表示是T的一个未知父类。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。