泛型的概念:
简单地讲,就是同一个方法(类),可以接受不同的数据类型并运行得到相对应的结果,不会出现安全问题
上一篇有一段这样的代码:
没有定义集合类型、迭代器类型
package demo; import java.util.ArrayList; import java.util.Collection; import java.util.Iterator; public class CollectionDemo { public static void main(String[] args) { //集合可以存储任意类型的对象 //集合中,不指定存储的数据类型,也可以存储 Collection c1 = new ArrayList(); c1.add("abc"); c1.add("def"); Iterator it1 = c1.iterator(); while(it1.hasNext()){ //it.next获取Object类型,强制转换 String s1 = (String)it1.next(); System.out.println(s1.length()); } } }
这里会有隐患:如果add(1);,自动装箱成Integer类型,无法转换成String,发生类型的转换异常
java中提出了泛型的概念,来解决这个问题:
package demo; import java.util.ArrayList; import java.util.Collection; import java.util.Iterator; public class GenericDemo { public static void main(String[] args) { function(); } public static void function(){ Collection<String> c1 = new ArrayList<String>(); c1.add("abc"); c1.add("def"); Iterator<String> it1 = c1.iterator(); while(it1.hasNext()){ String s1 = it1.next(); System.out.println(s1); } } }
这时候如果add(1);,在编译的时候会无法通过,解决了安全问题
其实这里的泛型,是伪泛型,这里只是一个编译的手段,如果不是String类型,编译无法通过,否则编译成功
而编译后的class文件里面不存在泛型,但是由于编译过程中处理了类型问题,所以最后运行也是安全的
泛型的方法(了解即可,没有实际应用价值):
package demo; import java.util.ArrayList; public class GenericDemo { public static void main(String[] args) { ArrayList<Integer> array = new ArrayList<Integer>(); // ArrayList集合内有方法toArray泛型方法 array.add(123); array.add(456); Integer[] i = new Integer[(array.size())]; Integer[] j = array.toArray(i); for (Integer k : j) { System.out.println(k); } } }
同样存在泛型的接口,泛型类等,目的都是为了解决安全问题并且方便使用者,并且带来了增强for循环
泛型的通配符?:
package demo; import java.util.ArrayList; import java.util.Collection; import java.util.HashSet; import java.util.Iterator; public class GenericDemo { public static void main(String[] args) { ArrayList<String> array = new ArrayList<String>(); array.add("abc"); array.add("def"); HashSet<Integer> set = new HashSet<Integer>(); set.add(123); set.add(456); iterator(array); iterator(set); } //要求定义一个方法,可以同时迭代两个集合 public static void iterator(Collection<?> c){ Iterator<?> it1 = c.iterator(); while(it1.hasNext()){ System.out.println(it1.next()); } } }