vlambda博客
学习文章列表

干掉 fastjson!国产新一代 fastjson 2!

管她前浪,还是后浪?

能浪的浪,才是好浪!

每天 10:33 更新文章,每天掉亿点点头发...

源码精品专栏

 





FASTJSON 2.0是FASTJSON项目的重要升级,目标是为下一个十年提供一个高性能的JSON库,同一套API支持JSON/JSONB两种协议,JSONPath是一等公民,支持全量解析和部分解析,支持Java服务端、客户端Android、大数据场景。

  • FASJTONS2代码 https://github.com/alibaba/fastjson2/releases/tag/2.0.1
  • JSONB格式文档 https://github.com/alibaba/fastjson2/wiki/jsonb_format_cn
  • FASTJSON 2性能有了很大提升,具体性能数据看这里 https://github.com/alibaba/fastjson2/wiki/fastjson_benchmark

基于 Spring Boot + MyBatis Plus + Vue & Element 实现的后台管理系统 + 用户小程序,支持 RBAC 动态权限、多租户、数据权限、工作流、三方登录、支付、短信、商城等功能。

在fastjson 2.0中,groupId和1.x不一样,是com.alibaba.fastjson2

<dependency>
 <groupId>com.alibaba.fastjson2</groupId>
 <artifactId>fastjson2</artifactId>
 <version>2.0.1</version>
</dependency>

https://repo1.maven.org/maven2/com/alibaba/fastjson2/fastjson2/

如果原来使用fastjson 1.2.x版本,可以使用兼容包,兼容包不能保证100%兼容,请仔细测试验证,发现问题请及时反馈。

<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>fastjson</artifactId>
  <version>2.0.1</version>
</dependency>

在fastjson 2.0中,package和1.x不一样,是com.alibaba.fastjson2。如果你之前用的是fastjson1,大多数情况直接更包名就即可。

package com.alibaba.fastjson2;

class JSON {
  // 将字符串解析成JSONObject
  static JSONObject parseObject(String str);

  // 将字符串解析成JSONArray
  static JSONArray parseArray(String str);

  // 将字符串解析成Java对象
  static T parseObject(byte[] utf8Bytes, Class<T> objectClass);

  // 将Java对象输出成字符串
  static String toJSONString(Object object);

  // 将Java对象输出成UT8编码的byte[]
  static byte[] toJSONBytes(Object object);
}

class JSONB {
  // 将jsonb格式的byte[]解析成Java对象
  static T parseObject(byte[] jsonbBytes, Class<T> objectClass);

  // 将Java对象输出成jsonb格式的byte[]
  static byte[] toBytes(Object object);
}

class JSONObject {
  Object get(String key);
  int getIntValue(String key);
  Integer getInteger(String key);
  long getLongValue(String key);
  Long getLong(String key);
  getObject(String key, Class<T> objectClass);

  // 将JSONObject对象转换为Java对象
  toJavaObject(Class<T> objectClass);
}

class JSONArray {
  Object get(int index);
  int getIntValue(int index);
  Integer getInteger(int index);
  long getLongValue(int index);
  Long getLong(int index);
  getObject(int index, Class<T> objectClass);
}

class JSONPath {
  // 构造JSONPath
  static JSONPath of(String path);

  // 根据path直接解析输入,会部分解析优化,不会全部解析
  Object extract(JSONReader jsonReader);

  // 根据path对对象求值
  Object eval(Object rootObject);
}

class JSONReader {
  // 构造基于String输入的JSONReader
  static JSONReader of(String str);

  // 构造基于ut8编码byte数组输入的JSONReader
  static JSONReader of(byte[] utf8Bytes);

  // 构造基于char[]输入的JSONReader
  static JSONReader of(char[] chars);

  // 构造基于json格式byte数组输入的JSONReader
  static JSONReader ofJSONB(byte[] jsonbBytes)
}

基于微服务的思想,构建在 B2C 电商场景下的项目实战。核心技术栈,是 Spring Boot + Dubbo 。未来,会重构成 Spring Cloud Alibaba 。

String str = "{\"id\":123}";
        JSONObject jsonObject = JSON.parseObject(str);
        int id = jsonObject.getIntValue("id");
        String str = "[\"id\", 123]";
        JSONArray jsonArray = JSON.parseArray(str);
        String name = jsonArray.getString(0);
        int id = jsonArray.getIntValue(1);

class Product {
  public int id;
  public String name;
}

  Product product = new Product();
product.id = 1001;
        product.name = "DataWorks";

        JSON.toJSONString(product);

// 生成如下的结果
        {
        "id" : 1001,
        "name" : "DataWorks"
        }

        JSON.toJSONString(product, JSONWriter.Feature.BeanToArray);
// 生成如下的结果
        [123"DataWorks"]

Product product = ...;
        byte[] utf8JSONBytes = JSON.toJSONBytes(product);

Product product = ...;
        byte[] jsonbBytes = JSONB.toBytes(product);

        byte[] jsonbBytes = JSONB.toBytes(product, JSONWriter.Feature.BeanToArray);

String str = "{\"id\":123}";
        Product product = JSON.parseObject(str, Product.class);

byte[] utf8Bytes = "{\"id\":123}".getBytes(StandardCharsets.UTF_8);
        Product product = JSON.parseObject(utf8Bytes, Product.class);

byte[] jsonbBytes = ...
        Product product = JSONB.parseObject(jsonbBytes, Product.class);

        Product product = JSONB.parseObject(jsonbBytes, Product.classJSONReader.Feature.SupportBeanArrayMapping);

String str = ...;

        JSONPath path = JSONPath.of("$.id"); // 缓存起来重复使用能提升性能

        JSONReader parser = JSONReader.of(str);
        Object result = path.extract(parser);

byte[] utf8Bytes = ...;

        JSONPath path = JSONPath.of("$.id"); // 缓存起来重复使用能提升性能

        JSONReader parser = JSONReader.of(utf8Bytes);
        Object result = path.extract(parser);

byte[] jsonbBytes = ...;

        JSONPath path = JSONPath.of("$.id"); // 缓存起来重复使用能提升性能

        JSONReader parser = JSONReader.ofJSONB(jsonbBytes); // 注意,这是利用ofJSONB方法
        Object result = path.extract(parser);


已在知识星球更新源码解析如下:

最近更新《芋道 SpringBoot 2.X 入门》系列,已经 101 余篇,覆盖了 MyBatis、Redis、MongoDB、ES、分库分表、读写分离、SpringMVC、Webflux、权限、WebSocket、Dubbo、RabbitMQ、RocketMQ、Kafka、性能测试等等内容。

提供近 3W 行代码的 SpringBoot 示例,以及超 4W 行代码的电商微服务项目。

文章有帮助的话,在看,转发吧。

谢谢支持哟 (*^__^*)