泛型概述

  • 泛型:是JDK5引入的特性,可以在编译阶段约束操作的数据类型,并进行检查。
  • 泛型的格式:<数据类型>
  • 注意:泛型只能支持引用数据类型

没有使用泛型的时候:

1.如果我们没有给集合指定类型,默认认为所有的数据类型都是Object类型

2.此时可以往集合添加任意的数据类型

3.坏处就是我们在获取数据的时候,无法使用他的特有行为

4.这种时候就推出了泛型,可以把添加数据的时候就把类型进行统一

好处:

1.统一数据类型

2.在运行时期的问题提前到了编译期间,避免了强制类型转换可能出现的异常,因为在编译阶段类型就确定下来了

Java中的而泛型其实是一个伪泛型,因为只是在存的时候做了个数据判断,实际上存进去的还是Object类型的数据

细节:

1.泛型中不能写基本数据类型,必须写他的包装类

2.指定泛型的具体类型后,传递数据是,可以传入该类型或者其子类型(继承)

3.如果不写泛型,类型默认的是Object

泛型类

  • 使用场景:当一个类中,某个变量的数据类型不确定时,就可以定义带有泛型的类、
  • 格式: 修饰符 class 类名<类型>{}
  • 例如:public class ArrayList
    {} 创建该类对象时,E就确定类型

此处的E可以理解为变量,但是不是用来记录数据的,而是记录数据的类型,可以写成:E,T,K,V等

泛型方法

方法中形参类型不确定时,可以使用类后面定义的泛型

例如:

public<E> boolean add(E e){
    return true;
}

方法一:使用类后面定义的泛型 (所有方法都可以用)

方法二:在方法声明定义自己的泛型 (只有本方法能用)

泛型方法类型练习

import java.util.ArrayList;

public class Test {
    public static void main(String[] args) {
        //定义一个工具类:ListUtil
        //类中定义一个静态方法addAll,用来添加多个集合的元素
        ArrayList<String> list=new ArrayList<>();
        ListUtil.addAll(list,"aaa","bbb");
        System.out.println(list);
    }
}
import java.util.ArrayList;

public class ListUtil<E> {
    private ListUtil(){}

    public static<E> void addAll(ArrayList<E> list,E...e){
        for (E element:e) {
            list.add(element);
        }
    }
}

泛型接口

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

重点:如何使用一个带泛型的接口

方式1:实现类给出具体类型

方式2:实现类延续泛型,创建对象时候再确定

方式1代码演示:

public class Demo1 {
    public static void main(String[] args) {
        /*方式1:实现类给出具体类型

         方式2:实现类延续泛型,创建对象时候再确定*/
        MyArrayList2 list=new MyArrayList2();
        list.add("123");
    }
}
import java.util.Collection;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;

public class MyArrayList2 implements List<String> {
    @Override
    public int size() {
        return 0;
    }

    @Override
    public boolean isEmpty() {
        return false;
    }

    @Override
    public boolean contains(Object o) {
        return false;
    }

    @Override
    public Iterator<String> iterator() {
        return null;
    }

    @Override
    public Object[] toArray() {
        return new Object[0];
    }

    @Override
    public <T> T[] toArray(T[] a) {
        return null;
    }

    @Override
    public boolean add(String s) {
        return false;
    }

    @Override
    public boolean remove(Object o) {
        return false;
    }

    @Override
    public boolean containsAll(Collection<?> c) {
        return false;
    }

    @Override
    public boolean addAll(Collection<? extends String> c) {
        return false;
    }

    @Override
    public boolean addAll(int index, Collection<? extends String> c) {
        return false;
    }

    @Override
    public boolean removeAll(Collection<?> c) {
        return false;
    }

    @Override
    public boolean retainAll(Collection<?> c) {
        return false;
    }

    @Override
    public void clear() {

    }

    @Override
    public String get(int index) {
        return null;
    }

    @Override
    public String set(int index, String element) {
        return null;
    }

    @Override
    public void add(int index, String element) {

    }

    @Override
    public String remove(int index) {
        return null;
    }

    @Override
    public int indexOf(Object o) {
        return 0;
    }

    @Override
    public int lastIndexOf(Object o) {
        return 0;
    }

    @Override
    public ListIterator<String> listIterator() {
        return null;
    }

    @Override
    public ListIterator<String> listIterator(int index) {
        return null;
    }

    @Override
    public List<String> subList(int fromIndex, int toIndex) {
        return null;
    }
}

方式2代码演示:

MyArrayList3<String> list1=new MyArrayList3<>();
public class MyArrayList3<E> implements List<E>

原文地址:http://www.cnblogs.com/lovedong/p/16875443.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性