Java_泛型集合的定义及使用

简介: Java_泛型集合的定义及使用

泛型集合的定义及使用

引入

什么是泛型、为什么要引入泛型、泛型类和泛型方法的使用

实例泛型:

​ 创建对象时,为类所定义的泛型,进行参数化赋值。

  • 类:创建对象时,为类所定义的泛型,进行参数化赋值
  • 接口:实现接口时,为接口所定义的泛型,进行参数化赋值

静态泛型:

  • 定义在方法的返回值类型前面:、、>、> 可应用在形参列表、返回值两种场景上,不单单可以规范泛型,还可以语义化返回值。
  • 定义在方法的形参列表当中:<?>、<? extends Object>、<? super Integer>,不支持使用& 只能应用在形参列表上,规范泛型。

1 概述

          一种约束---规范类型(常用名字:E = Elememt、T = Type、K = Key、V = Value),将类型的明确工作提前到对象的创建以及方法调用,防止程序不安全泛型 :将类型的明确工作提前到对象的创建以及方法调用,防止程序不安全;参数化类型、类型安全的集合,强制集合的类型必须一致;

特点:

  1. 编译时即可检查,而非运行时抛出异常
  2. 访问时,不必类型转换也就是拆箱
  3. 不同泛型之间引用不能相互赋值,泛型不存在多态。(左泛型不可为右父类)

2 泛型的好处

  1. 将运行时期异常提前到了编译时期;
  2. 在遍历集合时,避免了强制类型转换;
  3. 解决了程序黄色警告线的问题------>提高了程序的安全性;
public static void main(String[] args) {
   
        //创建一个ArrayList集合对象
        ArrayList<String> array = new ArrayList<String>() ;//后面:泛型推断

        //添加元素
        array.add("kaka") ;
        array.add("hello") ;
        array.add("java") ;
        array.add("javaee") ;

        //遍历
        Iterator<String> it = array.iterator() ;
        while(it.hasNext()) {
   
            String s = it.next() ;
            System.out.println(s);
        }
    }
  • 使用泛型集合时注意类型要保持一致,否则会出现类型转化异常(ClassCastException)

2.1 ArrayList集合存储自定义对象,加入泛型

需求:使用ArrayList集合存储自定义对象Student,加入泛型

1)定义一个学生类

2)创建集合对象 ArrayList

3)创建5个学生

5)将5个学生添加到集合中

6)创建迭代器

7)利用迭代器遍历集合

8)利用get(int index)+size()相结合的方式遍历

/*
 * 学生类
 */
public class Student {
   
    private String name ;
    private int age ;
    public Student() {
   
        super();
        // TODO Auto-generated constructor stub
    }
    public Student(String name, int age) {
   
        super();
        this.name = name;
        this.age = age;
    }
    public String getName() {
   
        return name;
    }
    public void setName(String name) {
   
        this.name = name;
    }
    public int getAge() {
   
        return age;
    }
    public void setAge(int age) {
   
        this.age = age;
    }
    @Override
    public String toString() {
   
        return "Student [name=" + name + ", age=" + age + "]";
    }
}
public static void main(String[] args){
   
        //创建一个ArrayList集合
        ArrayList<Student> array = new ArrayList<Student>() ;

        //创建学生对象
        Student s1 = new Student("曹操",35) ;//后知后觉
        Student s2 = new Student("蒋干",25) ;//不知不觉
        Student s3 = new Student("诸葛亮",30) ;//先知先觉

        array.add(s1) ;
        array.add(s2) ;
        array.add(s3) ;

        //迭代器
        Iterator<Student> it = array.iterator() ;
        while(it.hasNext()) {
   
            Student s = it.next() ;
            System.out.println(s.getName()+"---"+s.getAge());
        }
        System.out.println("----------------------------");

        //普通for循环:get(int index)+size()相结合
        for(int x = 0 ; x < array.size() ; x ++) {
   
            Student s = array.get(x) ;
            System.out.println(s.getName()+"---"+s.getAge());
        }
    }

3 泛型的应用

泛型主要应用在集合中:

  • 定义在类中
  • 定义在接口中
  • 定义在方法中

3.1 泛型类

把泛型定义在类上

格式:

  • public class 类名<泛型类型1,…>

    泛型类型必须是引用类型

/*
 * 使用泛型:提高程序的安全性:将泛型定义类上
 */
public class ObjectTool<T>{
   
    //成员变量
    private  T obj ;

    //获取功能
    public T get() {
   
        return obj ;
    }

    //设置功能
    public void set(T obj) {
   
        this.obj = obj ;
    }
}
/*
 * 将泛型定义在类上     测试类
 */
 public static void main(String[] args) {
   
            //创建ObjectTool类的对象
            ObjectTool<String> ot = new ObjectTool<String>() ;

            //设置数据
            ot.set("卡卡"); 
            //获取数据
            String s = ot.get() ;
            System.out.println("姓名是:"+s);

            ObjectTool<Integer> ot2 = new ObjectTool<Integer>() ;

            //设置数据
            ot2.set(28);
            Integer i = ot2.get() ;
            System.out.println("年龄是:"+i);
        }

3.2 泛型方法

把泛型定义在方法上

格式:

  • public <泛型类型> 返回类型 方法名(泛型类型 .)
public class ObjectTool<T>{
           
    //将泛型定义在方法上
    public <T> void show(T t) {
   
        System.out.println(t);
    }
}
public static void main(String[] args) {
   
        //创建ObjectTool类的对象
        ObjectTool ot = new ObjectTool() ;
        ot.show("hello");
        ot.show(true);
        ot.show(100);
        ot.show(12.34);
    }

3.3 泛型接口

把泛型定义在接口上

格式:

  • public interface 接口名<泛型类型1…>

3.1 实现类已经明确数据类型

/*
 * 定义在接口上
 */
public interface Inter<T> {
   
    public abstract void show(T t);
}
/*
 * 测试类
 */
public class InterDemo {
   
    public static void main(String[] args) {
   
        //接口多态
        //第一种
        Inter i = new InterImpl();
        i.show("kaka");//kaka
    }
}
/*
 * 接口子实现类
 */
public class InterImpl implements Inter<String>{
   

    public void show(String t) {
   
        // TODO Auto-generated method stub
        System.out.println(t);
    }
}

3.2 子实现类没有明确数据类型

/*
 * 定义在接口上
 */
public interface Inter<T> {
   
    public abstract void show(T t);
}
/*
 * 测试类
 */
public class InterDemo {
   
    public static void main(String[] args) {
   
        //不明确数据类型
        Inter<Integer> i1 = new InterImpl<Integer>();
        i1.show(100);//100
        Inter<String> i2 = new InterImpl<String>();
        i2.show("kaka");//kaka
    }
}
/*
 * 接口子实现类
 */
public class InterImpl<T> implements Inter<T>{
   

    @Override
    public void show(T t) {
   
        // TODO Auto-generated method stub
        System.out.println(t);
    }
}

4. 高级泛型_通配符

关于泛型的通配符号:

  • <?>:任意Java类型(Object),可以自定义的类型,或者是JDK提供的任意Java类;
  • <? extends E>:向下限定E类型以及其他子类;
  • <? super E>:向上限定E类型以及其他的父类;
public class Generic{
   
    public static void main(String[] args) {
   
        //<?>
        //创建集合类型Collection集合
        Collection<?> c1 = new ArrayList<Object>();
        Collection<?> c2 = new ArrayList<Animal>();
        Collection<?> c3 = new ArrayList<Dog>();
        Collection<?> c4 = new ArrayList<Cat>();

        //<? extends E>
        Collection<? extends Animal> c5 = new ArrayList<Animal>();
        Collection<? extends Animal> c6 = new ArrayList<Dog>();
        Collection<? extends Animal> c7 = new ArrayList<Cat>();
//        Collection<? extends Animal> c8 = new ArrayList<Object>();错误

        //<? super E>
        Collection<? super Animal> c9 = new ArrayList<Object>();
        Collection<? super Dog> c10 = new ArrayList<Animal>();
        Collection<? super Cat> c11 = new ArrayList<Animal>();
//        Collection<? super Animal> c12 = new ArrayList<Dog>();错误


    }
}
class Animal{
   }
class Dog extends Animal{
   }
class Cat extends Animal{
   }
  • 注:在开发过程中,直接在创建集合的时候给定具体的存储类型
    • Collection<String> c = new ArrayList<String>();
目录
相关文章
|
10天前
|
算法 Java 数据处理
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。HashSet基于哈希表实现,提供高效的元素操作;TreeSet则通过红黑树实现元素的自然排序,适合需要有序访问的场景。本文通过示例代码详细介绍了两者的特性和应用场景。
30 6
|
10天前
|
存储 Java
深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。
【10月更文挑战第16天】本文深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。HashSet基于哈希表实现,添加元素时根据哈希值分布,遍历时顺序不可预测;而TreeSet利用红黑树结构,按自然顺序或自定义顺序存储元素,确保遍历时有序输出。文章还提供了示例代码,帮助读者更好地理解这两种集合类型的使用场景和内部机制。
27 3
|
10天前
|
存储 Java 数据处理
Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位
【10月更文挑战第16天】Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位。本文通过快速去重和高效查找两个案例,展示了Set如何简化数据处理流程,提升代码效率。使用HashSet可轻松实现数据去重,而contains方法则提供了快速查找的功能,彰显了Set在处理大量数据时的优势。
20 2
|
6天前
|
安全 Java 程序员
深入Java集合框架:解密List的Fail-Fast与Fail-Safe机制
本文介绍了 Java 中 List 的遍历和删除操作,重点讨论了快速失败(fail-fast)和安全失败(fail-safe)机制。通过普通 for 循环、迭代器和 foreach 循环的对比,详细解释了各种方法的优缺点及适用场景,特别是在多线程环境下的表现。最后推荐了适合高并发场景的 fail-safe 容器,如 CopyOnWriteArrayList 和 ConcurrentHashMap。
34 5
|
5天前
|
Java API
[Java]泛型
本文详细介绍了Java泛型的相关概念和使用方法,包括类型判断、继承泛型类或实现泛型接口、泛型通配符、泛型方法、泛型上下边界、静态方法中使用泛型等内容。作者通过多个示例和测试代码,深入浅出地解释了泛型的原理和应用场景,帮助读者更好地理解和掌握Java泛型的使用技巧。文章还探讨了一些常见的疑惑和误区,如泛型擦除和基本数据类型数组的使用限制。最后,作者强调了泛型在实际开发中的重要性和应用价值。
[Java]泛型
|
8天前
|
安全 Java 程序员
Java集合之战:ArrayList vs LinkedList,谁才是你的最佳选择?
本文介绍了 Java 中常用的两个集合类 ArrayList 和 LinkedList,分析了它们的底层实现、特点及适用场景。ArrayList 基于数组,适合频繁查询;LinkedList 基于链表,适合频繁增删。文章还讨论了如何实现线程安全,推荐使用 CopyOnWriteArrayList 来提升性能。希望帮助读者选择合适的数据结构,写出更高效的代码。
28 3
|
10天前
|
存储 Java 数据处理
Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。
【10月更文挑战第16天】Java Set:无序之美,不重复之魅!Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。通过 hashCode() 和 equals() 方法实现唯一性,适用于需要唯一性约束的数据处理。示例代码展示了如何使用 HashSet 添加和遍历元素,体现了 Set 的高效性和简洁性。
19 4
|
10天前
|
Java 开发者
在Java集合世界中,Set以其独特的特性脱颖而出,专门应对重复元素
在Java集合世界中,Set以其独特的特性脱颖而出,专门应对重复元素。通过哈希表和红黑树两种模式,Set能够高效地识别并拒绝重复元素的入侵,确保集合的纯净。无论是HashSet还是TreeSet,都能在不同的场景下发挥出色的表现,成为开发者手中的利器。
22 2
|
5月前
|
Java API 容器
Java泛型的继承和通配符
Java泛型的继承和通配符
32 1
|
6月前
|
安全 Java API
Java一分钟之-泛型通配符:上限与下限野蛮类型
【5月更文挑战第19天】Java中的泛型通配符用于增强方法参数和变量的灵活性。通配符上限`? extends T`允许读取`T`或其子类型的列表,而通配符下限`? super T`允许向`T`或其父类型的列表写入。野蛮类型不指定泛型,可能引发运行时异常。注意,不能创建泛型通配符实例,也无法同时指定上下限。理解和适度使用这些概念能提升代码的通用性和安全性,但也需兼顾可读性。
64 3