目录
一、泛型和Object类的使用
泛型和Object类的区别主要是在使用的时机不同:
- 泛型:如果确定要用哪个对象,并且使用到这个对象里面的属性,选择用泛型,因为泛型代表着更精确的对象,能够使用对象里面独有的方法。
- Object:Object是所有类的父类,特别笼统,且只能使用固定的属性。只要有Object的地方,基本都能用泛型替代。
二、集合类使用泛型的原因
比如我们在使用List集合的时候,我们用List添加了一个对象进去,如果用的是List<Object>,那么无论我们向里面添加什么样的对象,我们使用get方法获取到的都是Object类的方法,而没有添加进去的对象的方法。如下图所示:
而当我们使用的是泛型时,我们使用get方法可以获取到一个具体的对象,并且可以使用对象里定义的方法,如下图所示:
三、Object转化成具体泛型
实体类:
import lombok.Data;
/**
* 查询
*
* @author yunyan
* @date 2023/7/8
*/
@Data
public class QueryBO {
private Boolean query1;
private Boolean query2;
private Boolean query3;
}
测试类:
import java.util.ArrayList;
import java.util.List;
/**
* @author yunyan
* @date 2023/7/17
*/
public class Test {
public static void main(String[] args) {
List<Object> list1=new ArrayList<>();
QueryBO queryBO=new QueryBO();
queryBO.setQuery1(true);
list1.add(queryBO);
List<QueryBO> list2=new ArrayList<>();
for (Object o : list2) {
QueryBO item=(QueryBO) o;
list2.add(item);
}
}
}
结果是:
从上面代码也可以看出:如果使用Object类的话,没法保证返回的类型一定是QueryBO,也许是其它类型。这时你就会在运行时得到一个类型转换异常(ClassCastException)
四、使用泛型的好处
- 类型安全。 泛型的主要目标是提高 Java 程序的类型安全。通过知道使用泛型定义的变量的类型限制,编译器可以在一个高得多的程度上验证类型假设。没有泛型,这些假设就只存在于程序员的头脑中(或者如果幸运的话,还存在于代码注释中)。
- 消除强制类型转换。 泛型的一个附带好处是,消除源代码中的许多强制类型转换。这使得代码更加可读,并且减少了出错机会。
- 潜在的性能收益。 泛型为较大的优化带来可能。在泛型的初始实现中,编译器将强制类型转换(没有泛型的话,程序员会指定这些强制类型转换)插入生成的字节码中。但是更多类型信息可用于编译器这一事实,为未来版本的 JVM 的优化带来可能。由于泛型的实现方式,支持泛型(几乎)不需要 JVM 或类文件更改。所有工作都在编译器中完成,编译器生成类似于没有泛型(和强制类型转换)时所写的代码,只是更能确保类型安全而已。
五、泛型标记符
- E Element 集合元素
- T Type Java类
- K Key 键
- V Value值
- N Number 数值类型
- ?表示不确定的Java类型
其实 A-Z都可以作为泛型标记符,上面只是一种约定,增强代码的可读性,方便团队间的合作开发。