java--泛型

泛型

1.什么是泛型
泛型从字面上理解,是指一个类、接口或方法支持多种类型,使之广泛化、一般化和更加通用。Java中使用Object类来定义类型也 能实现泛型,但缺点是造成原类型信息的丢失。
2.泛型的使用:

package fanxing;

import com.sun.scenario.effect.impl.sw.sse.SSEBlend_SRC_OUTPeer;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;

public class Demo {
    public static void main(String[] args) {
        Collection c =new ArrayList();
        c.add("one");//这个有String
        c.add(2);//int类型
        c.add(3);
        Iterator it = c.iterator();
       //Object 为所有类的父类,所以可行
       /* while (it.hasNext()){
            Object obj =it.next();
            System.out.println("obj");
        }*/

        while (it.hasNext()){
            String s = it.next();
            System.out.println(s);
        }
    }
}

因为上述数组有String和int类型混杂的,编译报错在这里插入图片描述
String s =(String) it.next(),这里面做了所有类型的强项行转换了,编译没有错误,但是运行报错了Strigring) it.next();在这里插入图片描述

强制转换后运行报错,Integer不能转换成String在这里插入图片描述

Collection<String ->c =new ArrayList<String ->();
Iterator<String -> it = c.iterator();
对集合进行泛化处理,避免强制转换和让编译器不通过,提前报错。

package fanxing;

import com.sun.scenario.effect.impl.sw.sse.SSEBlend_SRC_OUTPeer;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;

public class Demo {
    public static void main(String[] args) {
    
        Collection<String> c =new ArrayList<String>();
        c.add("one");//这个有String
        c.add(2);//int类型
        c.add(3);
        Iterator<String> it = c.iterator();
       //Object 为所有类的父类,所以可行
       /* while (it.hasNext()){
            Object obj =it.next();
            System.out.println("obj");
        }*/

        while (it.hasNext()){
            String s = it.next();
            System.out.println(s);
        }
    }
}


泛型类

泛型类定义格式:
修饰符 class 类名{
}

类型为T,E.K.V任意一个,表示泛型

在这里插入图片描述

这个类的对象只能写string类型的
在这里插入图片描述
泛型通俗来说就是不知道啥型,用字符T代替类型,等测试需要时就构造什么类型的对象

package fanxing;

public class Student<T> {
    private T t;

    public T getT() {
        return t;
    }

    public void setT(T t) {
        this.t = t;
    }
}

测试类:

package fanxing;

import com.sun.org.apache.bcel.internal.generic.NEW;

public class Demo1 {
    public static void main(String[] args) {
    //定义String类型对象
        Student<String> student = new Student<String>();
        student.setT("www");//使用String类型
        //定义Integer类型对象
        Student<Integer> student1 = new Student<Integer>();
        student1.setT(12);


    }
}

泛型方法:

格式:

修饰符 class 类名<T> {
    public void play(T t);
——————————————————————————————或者
修饰符 class 类名{
	public <T> void play(T t);
	System.out.println(t);
}

就是方法里面的类型和变量名用T,t 代替;测试需要传什么参数,就定义什么类的对象即可

package fanxing;

public class Student<T> {
    private T t;

    public T getT() {
        return t;
    }

    public void setT(T t) {
        this.t = t;
    }
    public void paly(T t){
        System.out.println(t);
    }
}

测试类

package fanxing;

import com.sun.org.apache.bcel.internal.generic.NEW;

public class Demo1 {
    public static void main(String[] args) {
    //和使用getName 方法差不多
        Student<String> student = new Student<String>();
        student.paly("www");
        Student<Integer> student1 = new Student<Integer>();
        student1.paly(12);


    }
}

泛型方法在方法里面写该类型,等实际调用时,传进去是什么类型的,该方法就变成了什么类型的

package fanxing;

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

package fanxing;

import com.sun.org.apache.bcel.internal.generic.NEW;

public class Demo1 {
    public static void main(String[] args) {
        Student student = new Student();
        student.paly("www");
        Student student1 = new Student();
        student1.paly(12);


    }
}

泛型接口:

格式:

修饰符 interface 接口名<T>{}
package fanxing;

public interface Person <T  > {
    void eat(T t);
}

package fanxing;

public class Student<T> implements Person<T>{

    @Override
    public void eat(T t) {
        System.out.println(t);
    }
    }

package fanxing;

import com.sun.org.apache.bcel.internal.generic.NEW;

public class Demo1 {
    public static void main(String[] args) {
        Student<String> student = new Student<String>();
        student.eat("www");
        Student<Integer> student1 = new Student<Integer>();
        student1.eat(12);


    }
}


类型通配符:

格式:<?>
List<?> :表示元素类型未知,元素可以匹配任意类型;
这种带通配符的List仅仅表示它是各种泛型List的父类,并不能把元素添加其中。

类型通配符上限:<?extends 类型>
List<?extends Number>:表示类型是Number或其子类型
//extends 是继承,继承父类,所以是子类

类型通配符下限:<?super类型>
List<?super Number>:表示类型是Number或其父类型
//super是表示父类的,所以是其父类型

package fanxing;

import com.sun.org.apache.bcel.internal.generic.NEW;

import java.util.ArrayList;
import java.util.List;

public class Demo1 {
    public static void main(String[] args) {
    //1、无边界的通配符
        List<?> list =new ArrayList<Object>();
        List<?> list1 =new ArrayList<String>();
        List<? extends Number> list3 =new ArrayList<Number>();
        List<?super Number> list4 =new ArrayList<Number>();
       list.add("1");
       list1.add("1");
       list4.add(2);
       list3.add();

    }
}

在这里插入图片描述

1、无边界的通配符

        List<?> list =new ArrayList<Object>();

无边界的通配符的主要作用就是让泛型能够接收未知类型的数据。

但是我们不能对List<?>使用add()方法,仅有一个例外就是add(null)
从上面的总结可以看出,extends 通配符偏向于内容的获取,而 super 通配符更偏向于内容的存入。我们有一个 PECS 原则(Producer Extends Consumer Super)很好的解释了这两个通配符的使用场景。
Producer Extends 说的是当你的情景是生产者类型,需要获取资源以供生产时,我们建议使用 extends 通配符,因为使用了 extends 通配符的类型更适合获取资源。
Consumer Super 说的是当你的场景是消费者类型,需要存入资源以供消费时,我们建议使用 super 通配符,因为使用 super 通配符的类型更适合存入资源。

3.泛型的应用及优点:
1.使得一个类或方法中的类型参数化,最终达到代码复用的效果。( 不使用泛型,你可能需要每种情况的类或方法都要定义一遍 )
2.实现类型检查的功能,避免ClassCastException。
3.但如果你既想存入,又想取出,那么你最好还是不要使用 extends 或 super 通配符。

  • 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
发出的红包

打赏作者

gun_wqy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值