JAVA--泛型

一、为什么用泛型

早期的Object类型可以接收任意的对象类型,实际使用中存在类型转换问题,所以Java提供了泛型来解决这个安全问题。

二、什么是泛型

即“参数化类型”,就是将类型由原来的具体的类型参数化,类似于方法中的

变量参数,此时类型也定义成参数形式,然后在使用/调用时传入具体的

类型

泛型提供了编 译时类型安全检测机制

好处:在编译的时候能够检查类型安 全

三、泛型类

泛型类型用于类的定义中,被称为泛型类

通过泛型可以完成对一组类的操作对外开 放相同的接口

泛型的类型参数只能是类类型

.泛型的类型参数可以有多个

如果没有定义具体类型,默认为Object

import java.util.ArrayList;
import java.util.Date;

public class Demo {
    public static void main(String[] args) {
        /*
        ArrayList<E>  E -->参数   -->泛型
        泛型--> 参数化类型
        java中所有的集合类,都支持泛型,支持向类中,传入一个类型,
		建议集合中只存储一种类型 , 就不需要进行向下转型
         */

        /*
        //不使用泛型
        ArrayList list = new ArrayList();
        list.add(10);
        list.add("a");
        list.add(new Date());
        for(Object object : list){
            if(object instanceof String){
                String s = (String) object;
                System.out.println(object);
            }
            if(object instanceof Date){
                String s = (String)object;
                System.out.println(object);
            }
        }
         */

        //使用泛型
        ArrayList<String> list = new ArrayList();
        list.add("a");
        list.add("b");
        list.add("c");
        list.add("d");
        for(String s :list){
            System.out.println(s);
        }
    }
}

四、从泛型类派生子类

子类也是泛型类,子类和父类的泛型类型要一致

class A extends Demo

//如果一个子类继承(实现)父级类(接口)是有泛型的,
//那么子类也可以定义为一个泛型类
public class Person<T> implements Comparable<T> {

    public int compareTo(T o){
        return 0;
    }

    public static void main(String[] args) {
        Person<String> p =new Person<>();
    }
}

子类不是泛型类,父类要明确泛型的数据类型

class A extends Demo

//如果一个子类继承(实现)父级类(接口)是有泛型的,
//那么子类也可以不定义为泛型类,那么父类(接口)类型必须要明确才行
public class Person implements Comparable<Person>{
    public int compareTo(Person o){
        return 0;
    }

    public static void main(String[] args) {
        Person p = new Person();

    }
}

五、泛型接口

泛型接口与泛型类的定义及使用基本相同

子类也是泛型类,子类和父类的泛型类型要一致

子类不是泛型类,父类要明确泛型的数据类型

六、通配符,上边界,下边界

类型通配符一般是使用"?"代替具体的类型实参

public class Demo1<E> {
    /*
	方法中的参数的泛型实际可以为什么.
	test(Demo<?> d)  ? 类型通配符,指的是实际传入参数的类型, ?表示可以是任何类型
	*/
    public void test(Demo1<E> d){

    }
    public void test1(Demo1<? extends E> d1){
        //  ? extends E  泛型上限
        //  际传入参数的泛型,上限是E 以及E的子类
    }
    public void test2(Demo1<? super E> d2){
        // super E 泛型下限
        // 实际传入参数的泛型,下限是E 以及T的父类
    }
    public static void main(String[] args) {

		  Demo1 d0 = new Demo1<>();
		  Demo1<Integer> d1 = new Demo1<>();
		  Demo1<String> d2 = new Demo1<>();
		    d0.test(d1);
		    d0.test(d2);
/*
		  Demo1<Number> d0 = new Demo1<>();
		  Demo1<Integer> d1 = new Demo1<>();
		  Demo1<Number> d2 = new Demo1<>();
		    d0.test1(d1);
		    d0.test1(d2);*/
/*
        Demo1<Number> d0 = new Demo1<>();
        Demo1<Object> d1 = new Demo1<>();
        Demo1<Number> d2 = new Demo1<>();
        d0.test2(d1);
        d0.test2(d2);*/

    }
}

七、类型擦除

泛型代码能够很

好地和之前版本的代码兼容。那是因为,泛到信息只存在于代码编译阶段,在进入JVM之 前,与泛型相关的信息会被擦除掉,我们称之为一类型擦除。

泛型类被类型擦除后,相应的类型就被替换成 Object 类型或者上限类型

验证Ep:

import java.lang.reflect.Field;
import java.util.ArrayList;

public class Demo2<T> {
    public T name;
    public static void main(String[] args) throws NoSuchFieldException, SecurityException {
        // transient Object[] elementData;
        ArrayList<String> list  =  new ArrayList();
        //泛型只是在编译期间来对类型进行限制,底层还是Object类型.
        //这就是泛型类型擦除
        list.add("");

        Demo2<String> d2 = new Demo2<>();
        d2.name = "aaa";
        // d2.name = 1111;
        //同过反射机制,获取运行时的属性,结果发现,运行时,底层是Object类型
        Class c =   d2.getClass();
        Field f =  c.getField("name");
        System.out.println(f.getName()+":::"+f.getType());

    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: jmu-java-05集合(泛型)-10-generalstack是关于Java泛型中的通用栈的学习内容。通用栈是一种可以存储任意类型数据的栈结构,通过泛型的方式实现。在学习中,我们可以了解到通用栈的实现原理、使用方法以及注意事项等内容,帮助我们更好地理解和应用Java泛型。 ### 回答2: JMU-Java-05集合(泛型)-10-GeneralStack是一个Stack(栈)的实现类,使用Java中的泛型进行定义,可以存储任何类型的数据。 在该类中,使用一个Object类型的数组进行存储元素,并通过一个整型变量top来表示当前栈顶元素的下标。在push(入栈)方法中,先将top加一,然后将元素存储在数组中,实现了入栈的功能。在pop(出栈)方法中,先判断栈是否为空,若为空则抛出栈空异常,否则将top减一,并返回数组中相应的元素,实现了出栈的功能。其他方法如isEmpty(判断栈是否为空)、isFull(判断栈是否已满)和size(获取栈中元素个数)也在该类中实现。 该类的泛型定义使得我们可以使用该类存储任何类型的数据,而不需要在定义类时指定数据类型,提高了其灵活性和可复用性。在使用时,我们只需要在创建对象时传入相应的数据类型,如:GeneralStack<Integer> stack = new GeneralStack<Integer>();即可。 该类还实现了Iterable接口,使得该类可以使用foreach循环进行遍历操作,方便了我们对栈中元素的操作。同时,该类还通过对数组的动态扩容,解决了数组固定大小的限制问题,从而提高了该栈类的通用性和易用性。 总之,JMU-Java-05集合(泛型)-10-GeneralStack是一个使用泛型实现的通用栈类,可以存储各种类型的数据,并提供了常用的栈操作方法,具有较高的可复用性与适用性。 ### 回答3: jmu-java-05集合(泛型)-10-generalstack,意为基于泛型的栈实现。 首先我们需要了解什么是泛型泛型Java SE 5引入的一个新特性,它可以让我们在编写代码时定义一些未知的类型参数,以达到代码的复用和类型安全的目的。对于集合类或者其他容器类而言,适用于任何类的容器的需求是普遍存在的,这时就可以应用泛型。 在Java泛型使用<>标识,其语法格式如下: ```java public class 类名<类型参数列表> { //成员变量、方法等 } ``` 类型参数列表是由逗号隔开的参数列表,可以理解为未知类型的占位符。这样的好处是可以在编写集合类时,避免出现类型转换等一系列问题,提高程序的可读性。 而在jmu-java-05集合(泛型)-10-generalstack中,则是基于泛型实现的数据结构——栈。栈是一种后进先出(LIFO)的数据结构,它只允许在栈顶添加或删除元素,因此操作非常简单、快速并且高效。 在该实现中,栈的元素可以是任意类型,数据元素入栈则是通过 push() 方法实现的,出栈则是通过 pop() 方法实现的。其中,push() 方法用于向栈中添加新的元素,pop() 方法用于弹出并返回栈顶的元素。同时,还提供了 isEmpty() 方法、size() 方法等基本的栈操作方法。 总之,jmu-java-05集合(泛型)-10-generalstack是一种基于泛型实现的栈,提供了复用和类型安全的目的。其实现使用简便、高效、易于扩展等优点,广泛应用在Java开发中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值