Java基础—泛型

来源:互联网 发布:mac pr防抖cc2017 编辑:程序博客网 时间:2024/04/29 04:21

1、 泛型产生的原因

     JDK升级至1.5后,为了解决集合中不指定类型,增加的安全机制,通过强制规定输入集合中元素的类型,避免后面操作过程中的类型错误。使程序在运行中出现的错误的问题   转移到编译阶段。  

       (1)定义泛型方法

                 在类中的方法支持多个数据类型,就需要对方法进行重载,在引入范型后,可以解决此问题(多态),更进一步可以定义多个参数以及返回值之间的关系。

                    重载方式

                       public void write(Integer i, Integer[] ia);
                        public void write(Double  d, Double[] da);
                  泛型:
                   public <T> void write(T t, T[] ta);

     (2)  定义泛型类:

          当要操作的引用数据不确定,早期定义Object类来拓展,但是面临期操作过程中(编译能通过),需要强转。现在用泛型类来定义。定义泛型类时,对于类中的方法都可以通过泛型对象调用,只要确定具体类型,操作就固定了。(对于方法的类型单一)。

        class < T >{

               private T t;

               public   T  Methid(T  m){

                ..............     

                 }

               }

                 定义之后,在该类的作用域内,均可使用该类型。


2、  泛型限定

           (1)  限定特点

                   泛型是编译期检查的,匹配引用类型。 
                          ArrayList<Animal> list = new ArrayList<Animal>();
                          Animal animal = new Animal();
                          Animal cat = new Cat();
                         Cat cat2 = new Cat();
                          list.add(animal);//ok
                          list.add(cat);//ok
                          list.add(cat2);//complile error

           (2)

                       限定下限:

            一般用于定义 迭代器: 只需定义 父类类型的迭代器,否则 面向具体的话,扩展性和维护性不好

class Personed {private String Name;private int Age;public String getName() {return Name;}public int getAge() {return Age;}public Personed(String name, int age) {super();this.Name = name;this.Age = age;}}class Student extends Personed {public Student(String name, int age) {super(name, age);// TODO Auto-generated constructor stub}}class Teacher extends Personed {public Teacher(String name, int age) {super(name, age);}}class CompareByAge implements Comparator<Personed> {public int compare(Personed s1, Personed s2) {int num = new Integer(s1.getAge()).compareTo(new Integer(s2.getAge()));if (num == 0)return s1.getName().compareTo(s2.getName());return num;}}class Demo13 {// TreeSet<E>(Comparator<? super E> comparator)// 定义比较器时,可以是E类型,还可以是E的父类型,E在创建集合对象时确定public static void main(String[] args) {TreeSet<Student> t1 = new TreeSet<Student>(new CompareByAge());t1.add(new Student("zhaosi", 23));t1.add(new Student("lisi", 25));t1.add(new Student("wangwu", 20));TreeSet<Teacher> t2 = new TreeSet<Teacher>(new CompareByAge());t2.add(new Teacher("wang", 38));t2.add(new Teacher("lilaoshi", 48));t2.add(new Teacher("zhanglaoshi", 58));}}

               限定上限:

定义父类 填装子类 类型!

import java.util.*;    //泛型限定上限的应用    class Demo12   {      public static void main(String[] args)       {           Collection<Student> c = new ArrayList<Student>();            c.add(new Student("zhaosi",23));          c.add(new Student("lisi",25));          c.add(new Student("wangwu",20));                //TreeSet(Collection<? extends E> c)         // class TreeSet<E>         //{         //}          TreeSet<Person> ts = new TreeSet<Person>(c);            Iterator<Person> ite = ts.iterator();          while(ite.hasNext())          {              sop(ite.next());          }      }            public static void sop(Object obj)      {          System.out.println(obj);      }  }  




0 0