Java中泛型的用法总结
本文实例总结了Java中泛型的用法。分享给大家供大家参考。具体如下:
1 基本使用
public interface List<E> {
void add(E);
Iterator<E> iterator();
}
2 泛型与子类
Child是Parent的子类,List<Child>却不是List<Parent>的子类。
因此:List<Object> list = new ArrayList<String>()是错误的。
如果上面是正确的,那么:
List<String> ls = new ArrayList<String>(); //1 List<Object> lo = ls; //2 lo.add(new Object()); // 3 String s = ls.get(0); // 4,将object转换为string将失败。
3 wildcards
因为2的原因,下面的实现用于统配集合的输出是不行的
void printCollection(Collection<Object> c) {
for (Object o: c) {
// do something
}
}
因此,需要通配符?:
void printCollection(Collection<?> c) {
for (Object o: c) { // 1
// do something
}
} // ok
此处的?表示类型未知,但是任何对象均是Object,因此上例的1是正确的。但下例却是错误的:
void add(Collection<? extends MyClass> c) {
c.add(new MyClass()); // wrong
} // ok
原因也很明确,? extends MyClass说明类型是MyClass的子类,但是却并不知道具体类型
4. 泛型方法
上例可以实现为:
<T> add(Collection<T> c, T t) {
c.add(t);
}
编译器在保证语义的前提,会帮忙做类型的转换工作。
5. 泛型运行时的对比
List<String> l1 = new ArrayList<String>(); List<Integer> l2 = new ArrayList<Integer>(); System.out.println(l1.getClass() == l2.getClass()); // true
因为泛型类运行时时一样的。
6 泛型数组(可能导致类型不安全)
如果可以的话,可能导致类型不安全。如:
Object o = lsa; Object []oa = (Object[])o; List<Integer> li = new ArrayList<Integer>(); li.add(new Integer(3)); oa[1] = li; String s = lsa[1].get(0); // runtime error
希望本文所述对大家的java程序设计有所帮助。
相关文章
如何解决SpringBoot2.6及之后版本取消了循环依赖的支持问题
循环依赖指的是两个或者多个bean之间相互依赖,形成一个闭环,SpringBoot从2.6.0开始默认不允许出现Bean循环引用,解决方案包括在全局配置文件设置允许循环引用存在、在SpringApplicationBuilder添加设置允许循环引用、构造器注入2024-10-10
如何使用IntelliJ IDEA中的Live Templates自定义代码模板
在IntelliJ IDEA中,通过使用LiveTemplates功能,可以实现快速编码和自定义代码模板,例如,输入“main”可以自动补全主函数结构,“sout”可以补全输出语句,用户可以通过设置中的LiveTemplates选项查看和定义快捷模板,支持使用分组管理和参数化模板内容,适应复杂的编码需求2024-11-11
java.util.Collections类—emptyList()方法的使用
这篇文章主要介绍了java.util.Collections类—emptyList()方法的使用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-11-11
idea创建springboot项目,java版本只能选择17和21的解决方案
这篇文章主要介绍了idea创建springboot项目,java版本只能选择17和21的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2025-04-04


最新评论