1.什么是泛型泛型泛型编程?
2.Java泛型 | Jackson TypeReference获取泛型类型信息
3.泛型的本质是什么
什么是泛型编程?
泛型编程是一种编程范式,它允许开发者编写可以在多种数据类型上工作的源码源码代码。
在C++中,解析泛型编程主要通过函数模板和类模板实现。泛型泛型在过去的源码源码C语言编程中,针对不同类型的解析自助发卡源码参数,需要编写不同的泛型泛型函数。
然而,源码源码C++的解析模板引入后,可以创建函数模板,泛型泛型这些模板能够接受多种类型参数,源码源码而无需为每种类型单独编写函数。解析vue年会摇一摇活动源码这意味着同一个模板可以被多种数据类型调用,泛型泛型同时保持代码的源码源码正确性和一致性。
使用泛型编程,解析开发者可以编写出高度可重用且具有强大灵活性的代码。通过泛型编程,可以编写出适用于多种数据类型的通用算法和数据结构,减少重复代码,提高代码效率和可维护性。
泛型编程的另一个优点是它提高了代码的可移植性。由于模板代码在编译时会被替换为针对特定类型的代码,因此程序可以在不修改源代码的通达信操盘线线公式源码情况下,轻松在不同平台或环境上运行。
总的来说,泛型编程是一种强大且灵活的编程技术,能够提高代码的效率、可重用性和可移植性。通过使用模板,开发者可以创建适用于多种数据类型的功能,从而简化代码编写和维护过程。
Java泛型 | Jackson TypeReference获取泛型类型信息
前言
Jackson 是一个流行的 Json 序列化和反序列化框架,本文将探讨如何利用 TypeReference 实现涉及泛型的反序列化,并深入解析 TypeReference 的易语言无名模块锁机源码实现原理。对于需要获取泛型类型信息的场景,TypeReference 提供了一个通用的解决方案。
实例
Jackson 的 ObjectMapper 可以将 Json 字符串反序列化为 Java 对象。例如,以下代码将 Json 字符串反序列化为 List 类型:
Json 字符串:
json
[{ "id":null,"name":" ","age":,"gender":false,"email":"email","employed":true,"salary":}]
UserResource 实体类:
java
public class UserResource {
private Integer id;
private String name;
private Integer age;
private boolean gender;
private String email;
private boolean employed;
private double salary;
}
理想的实现方式
理想的实现方式是明确告诉 ObjectMapper 的 readValue 方法,我们需要的是 List 类型,以便将其反序列化为指定类型。然而,Java 编译器会报错,指出无法从参数化类型中选择,这是控盘爆发启动副图公式源码由于 Java 编译器将 List 视为 Class 类型,而非具体类型。
换一种方式实现
既然直接使用 List.class 不可行,我们尝试通过告诉 ObjectMapper,我们想要的是 List 类型,但返回值类型为 List,会怎样呢?结果是,虽然编译没有错误,但会出现警告:`Unchecked assignment: 'java.util.List' to 'java.util.List'`。ObjectMapper 实际上无法将序列化结果反序列化为 UserResource 类型,而是将其反序列化为 LinkedHashMap 类型。
TypeReference 的实现方式
为解决上述问题,Jackson 提供了 ObjectMapper 的 readValue 方法,接受一个 TypeReference 类型的实例作为第二个参数。通过创建 TypeReference 的子类实例,如 `new TypeReference<List>() { }`,可以获取完整的泛型类型信息,并将 Json 字符串反序列化为指定泛型类型。
TypeReference 实现原理
TypeReference 的核心在于通过继承自 Class 类的 getGenericSuperclass 方法,获取父类中的参数化类型(ParameterizedType)。此方法返回一个 Type 类型的对象,该对象准确反映了源代码中使用的实际类型参数。
Class 的 genericInfo 属性
在获取到 ParameterizedType 后,通过调用 getActualTypeArguments 方法,可以获得泛型参数的实际类型。这样,即使在编译时无法显式指定类型参数,通过 TypeReference 也可以在运行时获取和使用泛型信息。
总结
泛型的本质是什么
泛型的本质是参数化类型。Java泛型(generics)这个特性提供了编译时类型安全检测机制,允许程序员在编译时检测到非法的类型。泛型的本质是参数化类型,即给类型指定一个参数,然后在使用时再指定此参数具体的值,那样这个类型就可以在使用时决定了。这种参数类型可以用在类、接口和方法中,分别被称为泛型类、泛型接口、泛型方法。
为了兼容之前的版本,Java泛型的实现采取了“伪泛型”的策略,即Java在语法上支持泛型,但是在编译阶段会进行所谓的“类型擦除”(Type Erasure),将所有的泛型表示(尖括号中的内容)都替换为具体的类型(其对应的原生态类型)。
泛型的好处
在没有泛型之前,从集合中读取到的每一个对象都必须进行类型转换,如果不小心插入了错误的类型对象,在运行时的转换处理就会出错。有了泛型后,会对类型进行验证,这个过程相当于告诉编译器每个集合接收的对象类型是什么,编译器在编译期就会做类型检查,告知是否插入了错误类型的对象,使得程序更加安全,增强了程序的健壮性。
泛型的另一个好处是消除源代码中的强制类型转换,这样代码可读性更强,且减少了转换类型出错的可能性。
泛型的另一个好处是消除源代码中的强制类型转换,这样代码可读性更强,且减少了转换类型出错的可能性。
引入泛型的另一个意义在于:适用于多种数据类型执行相同的代码(代码复用)。