fastJson序列化与反序列化

简介: fastJson序列化与反序列化

Java泛型是jdk1.5引入的一个新特性。泛型的本质是参数化类型,也就是说操作的数据类型被指定为一个参数。


Java泛型


泛型类

public class Pair < T , U >{
  private T first ;
  private U second ;
  ...
}


泛型方法


public static <E extends BoundingType> void sort(E e){
    ...
    }



注意:


1. 为 类型变量 需要特别注意他的位置。

2.extends BoundingType 给E添加限制条件,E应该是绑定类的BoundingType子类

3.E和BoundingType可以是接口也可以是类。

4.一个类型变量或通配符可以有多个限定。例如:<E extends Comparable & Serializable>

约束与局限性

不能用基本类型实例化类型参数。例如: Pair < double >

运行时类型查询只适用于原始类型。例如:if ( a instanceof Pair < String > ) // Error;if ( stringPair . getClassO = = employeePair . getClassO ) / / they are equal

不能创建参数化类型的数组。Pair < String > [ ] table = new Pair < String > [ 10 ] ; // Error

不能实例化类型变置。例如:new T ( ) ;

Varargs 警告 使用 @ SafeVarargs 标注来消除创建泛型数组的有关限制

不能构造泛型数组 :T[] a = new T [ 2 ] ;/ / Error

泛型类的静态上下文中类型变量无效:及不能在静态域或方法中引用类型变量;


public class Singleton < T >{
  private static T singlelnstance ; // Error
  public static T getSinglelnstanceO{ // Error
    if ( singleinstance = = null ) construct new instance of T
    return singlelnstance ;
  }
}


不能抛出也不能捕获泛型类对象:例如catch ( T e ) / / Error can ’ t catch type variable

可以消除对受查异常的检查:Java 异常处理的一个基本原则是 , 必须为所有受查异常提供一个处理器 。可以利用

泛型消除这个限制 。


@ SuppressWamings ( " unchecked " )
public static < T extends Throwable 〉 void throwAs ( Throwable e ) throws T
{
  throw CO e ;
}


假定我们有这样一个需求:写一个排序方法,能够对整型数组、字符串数组甚至其他任何类型的数组进行排序,该如何实现?(问题来源菜鸟教程)


    /**
     * 排序方法
     * @param list 列表
     * @param <E>  泛型定义为<E extends Comparable<E>>
     */
    public static <E extends Comparable<E>> void sort(E[] list){
        if (list == null || list.length == 0){
            return;
        }
        /**
         * 任意对象
         */
        E obj;
        /**
         * 列表下标
         */
        int index;
        //外层循环 从下表1开始
        for(int i = 0; i < list.length - 1; i++){
            //找到数组中最小的值
            obj = list[i];
            index = i;
            for(int j = i + 1; j < list.length; j++){
                /**
                 * 如果obj与参数相等返回 0。
                 * 如果obj小于参数返回 -1。
                 * 如果obj大于参数返回 1。
                 */
                if (obj.compareTo(list[j]) > 0){
                    obj = list[j];
                    index = j;
                }
            }
            if (index != i){
                list[index] = list[i];
                list[i] = obj;
            }
        }
    }


回顾了上面的泛型我们差不多可以进入正题了。序列化与反虚化,这里用的是fastJson工具。一般情况下的时候很简单。

这里将会使用到一个类TypeReference,他就是这次的主角。开头有这么一句话格外的刺耳。Represents a generic type {@code T}. Java doesn’t yet provide a way to represent generic types, so this class does.

翻译过来意思就是:表示一个泛型类型 {@code T}。 Java 还没有提供表示泛型类型的方法,所以这个类提供了。强制客户端创建此类的子类,即使在运行时也可以检索类型信息。

这里贴上该类的部分源码:


/**
 * 表示一个泛型类型 {@code T}。 Java 还没有提供表示泛型类型的方法,所以这个类提供了。
 * 强制客户端创建此类的子类,即使在运行时也可以检索类型信息。
 * 例如,要为 {@code List<String>} 创建一个类型文字,您可以创建一个空的匿名内部类:TypeReference<List<String>> list = new TypeReference<List<String>> () {};
 * 此语法不能用于创建具有通配符参数的类型文字,例如 {@code Class<?>} 或 {@code List<?扩展 CharSequence>}。
 *
 */
public class TypeReference<T> {
    static ConcurrentMap<Type, Type> classTypeCache
            = new ConcurrentHashMap<Type, Type>(16, 0.75f, 1);
    protected final Type type;
    /**
     * 构造一个新的类型文字。从类型参数派生表示的类。
     * 客户端创建一个空的匿名子类。这样做会将类型参数嵌入到匿名类的类型层次结构中,因此我们可以在运行时重构它,尽管会被擦除。
     */
    public TypeReference(){
        Type superClass = getClass().getGenericSuperclass();
        Type type = ((ParameterizedType) superClass).getActualTypeArguments()[0];
        Type cachedType = classTypeCache.get(type);
        if (cachedType == null) {
            classTypeCache.putIfAbsent(type, type);
            cachedType = classTypeCache.get(type);
        }
        this.type = cachedType;
    }
    ...
 }
相关文章
|
7月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
387 3
|
7月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
362 1
|
11月前
|
存储 Java 编译器
说一说关于序列化/反序列化中的细节问题
我是小假 期待与你的下一次相遇 ~
218 1
|
11月前
|
JSON Java 数据库连接
|
12月前
|
存储 安全 IDE
说一说序列化与反序列化中存在的问题
本文详细解析了Java中的序列化机制,包括序列化的概念、实现方式及应用场景。通过Student类的实例演示了对象的序列化与反序列化过程,并分析了`Serializable`接口的作用以及`serialVersionUID`的重要意义。此外,文章还探讨了如何通过自定义`readObject()`方法增强序列化的安全性,以及解决可序列化单例模式中可能产生的多实例问题。最后提供了代码示例和运行结果,帮助读者深入理解序列化的原理与实践技巧。
298 4
|
12月前
|
JSON JavaScript 前端开发
Go语言JSON 序列化与反序列化 -《Go语言实战指南》
本文介绍了 Go 语言中使用 `encoding/json` 包实现 JSON 与数据结构之间的转换。内容涵盖序列化(`Marshal`)和反序列化(`Unmarshal`),包括基本示例、结构体字段标签的使用、控制字段行为的标签(如 `omitempty` 和 `-`)、处理 `map` 和切片、嵌套结构体序列化、反序列化未知结构(使用 `map[string]interface{}`)以及 JSON 数组的解析。最后通过表格总结了序列化与反序列化的方法及类型要求,帮助开发者快速掌握 JSON 数据处理技巧。
|
存储 JSON fastjson
再也不用心惊胆战地使用FastJSON了——序列化篇
本篇将主要介绍json序列化的详细流程。本文阅读的FastJSON源码版本为2.0.31。
4525 49
|
存储 安全 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第22天】在Java的世界里,对象序列化和反序列化是数据持久化和网络传输的关键技术。本文将带你了解如何在Java中实现对象的序列化与反序列化,并探讨其背后的原理。通过实际代码示例,我们将一步步展示如何将复杂数据结构转换为字节流,以及如何将这些字节流还原为Java对象。文章还将讨论在使用序列化时应注意的安全性问题,以确保你的应用程序既高效又安全。
|
JSON 数据格式 索引
Python中序列化/反序列化JSON格式的数据
【11月更文挑战第4天】本文介绍了 Python 中使用 `json` 模块进行序列化和反序列化的操作。序列化是指将 Python 对象(如字典、列表)转换为 JSON 字符串,主要使用 `json.dumps` 方法。示例包括基本的字典和列表序列化,以及自定义类的序列化。反序列化则是将 JSON 字符串转换回 Python 对象,使用 `json.loads` 方法。文中还提供了具体的代码示例,展示了如何处理不同类型的 Python 对象。
803 1
|
存储 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第9天】在Java的世界里,对象序列化是连接数据持久化与网络通信的桥梁。本文将深入探讨Java对象序列化的机制、实践方法及反序列化过程,通过代码示例揭示其背后的原理。从基础概念到高级应用,我们将一步步揭开序列化技术的神秘面纱,让读者能够掌握这一强大工具,以应对数据存储和传输的挑战。

热门文章

最新文章