FastJson 数组、List、Set、Map基本序列化与日期格式化
摘要:
FastJson可以直接序列化数组、List、Set、Map等,也可以直接支持日期类型数据的格式化,包括java.util.Date、java.sql.Date、java.sql.Timestamp、java.sql.Time。
FastJson不仅可以支持普通数组、List、Set、Map序列化,也可以支持转载对应的数组、List、Set、Map序列化。
默认情况下,FastJson将Date类型序列化为long,序列化和反序列化的过程不会导致时区问题。
FastJson还提供了基于格式化输出的SerializerFeature。
数组、List、Set、Map基本序列化和反序列化,代码案例:
package com.what21.fastjson.fj02;
public class User {
// ID
private String id;
// 名称
private String name;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
package com.what21.fastjson.fj02; import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set; import com.alibaba.fastjson.JSON; /**
* 测试Main方法
*/
public class FastJsonMain { /**
* Array to JSON
*/
public static void array2Json(){
// 数组序列化
String[] array = new String[4];
array[0]="北京";
array[1]="上海";
array[2]="广州";
array[3]="深圳";
String json = JSON.toJSONString(array);
System.out.println("序列化 Array to JSON -> ");
System.out.println(json);
// 数组反序列化
array = (String[])JSON.parseObject(json,String[].class);
System.out.println("反序列化 数组内容 -> ");
System.out.print(array[0] + " ");
System.out.print(array[1] + " ");
System.out.print(array[2] + " ");
System.out.println(array[3]);
} /**
* List to JSON
*/
public static void list2Json(){
// List序列化
List<String> list = new ArrayList<String>();
list.add("北京");
list.add("上海");
list.add("广州");
list.add("深圳");
String json = JSON.toJSONString(list);
System.out.println("序列化 List to JSON -> ");
System.out.println(json);
// List反序列化
list = (List)JSON.parseObject(json,List.class);
System.out.println("反序列化 List内容 -> ");
System.out.println(list);
} /**
* Set to JSON
*/
public static void set2Json(){
// List序列化
Set<String> set = new HashSet<String>();
set.add("北京");
set.add("上海");
set.add("广州");
set.add("深圳");
String json = JSON.toJSONString(set);
System.out.println("序列化 Set to JSON -> ");
System.out.println(json);
// Set反序列化
set = (Set)JSON.parseObject(json,Set.class);
System.out.println("反序列化 Set内容 -> ");
System.out.println(set);
} /**
* Map to JSON
*/
public static void map2Json(){
Map<String,String> map = new HashMap<String,String>();
map.put("1","北京");
map.put("2","上海");
map.put("3","广州");
map.put("4","深圳");
String json = JSON.toJSONString(map);
System.out.println("序列化 Map to JSON -> ");
System.out.println(json);
// Map反序列化
map = (Map)JSON.parseObject(json,Map.class);
System.out.println("反序列化 Map内容 -> ");
System.out.println(map);
} /**
* Container to JSON
*/
public static void container2Json(){
List<String> list = new ArrayList<String>();
list.add("北京");
list.add("上海");
list.add("广州");
list.add("深圳");
Set<String> set = new HashSet<String>();
set.add("天津");
set.add("杭州");
set.add("青岛");
set.add("苏州");
Map<String,Object> map = new HashMap<String,Object>();
map.put("one", list);
map.put("two", set);
String jsonString = JSON.toJSONString(map);
System.out.println("Container to JSON -> ");
System.out.println(jsonString);
} /**
* @param args
*/
public static void main(String[] args) {
// 数组格式化输出
array2Json();
// List格式化输出
list2Json();
// Set格式化输出
set2Json();
// MAP格式化输出
map2Json();
// 混合容器格式化输出
container2Json();
} }
输出内容:
序列化 Array to JSON ->
["北京","上海","广州","深圳"]
反序列化 数组内容 ->
北京 上海 广州 深圳
序列化 List to JSON ->
["北京","上海","广州","深圳"]
反序列化 List内容 ->
[北京, 上海, 广州, 深圳]
序列化 Set to JSON ->
["北京","深圳","广州","上海"]
反序列化 Set内容 ->
[北京, 深圳, 广州, 上海]
序列化 Map to JSON ->
{"3":"广州","2":"上海","4":"深圳","1":"北京"}
反序列化 Map内容 ->
{3=广州, 2=上海, 4=深圳, 1=北京}
Container to JSON ->
{"one":["北京","上海","广州","深圳"],"two":["苏州","青岛","天津","杭州"]}
Java Date序列化和反序列化,代码案例:
package com.what21.fastjson.fj02; import java.util.Date;
import java.util.HashMap;
import java.util.Map; import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.serializer.SerializerFeature; /**
* 测试Main方法
*/
public class FastJsonDateMain { /**
* @param args
*/
public static void main(String[] args) {
// 时间
Date date = new Date();
String json = JSON.toJSONString(date);
System.out.println(json); // 格式化输出时间
String jsonStr = JSON.toJSONString(date,SerializerFeature.WriteDateUseDateFormat);
System.out.println(jsonStr); // 自定义格式输出
String dataFormat = "yyyy-MM-dd";
String timeFormat = "yyyy-MM-dd HH:mm:ss SSS";
String dateJson = JSON.toJSONStringWithDateFormat(date, dataFormat,
SerializerFeature.WriteDateUseDateFormat);
System.out.println(dateJson);
String jsonString = JSON.toJSONStringWithDateFormat(date, timeFormat);
System.out.println(jsonString); // 从容器中输出
Map<String,Date> map = new HashMap<String,Date>();
map.put("1", new Date());
map.put("2", new Date());
map.put("3", new Date());
String mapJson = JSON.toJSONStringWithDateFormat(map, dataFormat);
System.out.println(mapJson);
String mapJson2 = JSON.toJSONStringWithDateFormat(map, timeFormat);
System.out.println(mapJson2);
} }
输出内容:
1470841566893
"2016-08-10 23:06:06"
"2016-08-10"
"2016-08-10 23:06:06 893"
{"3":"2016-08-10","2":"2016-08-10","1":"2016-08-10"}
{"3":"2016-08-10 23:06:07 314","2":"2016-08-10 23:06:07 314","1":"2016-08-10 23:06:07 314"}
Java对象Map序列化和反序列化,代码案例:
package com.what21.fastjson.fj02; import java.util.HashMap;
import java.util.Map; import com.alibaba.fastjson.JSON; /**
* 测试Main方法
*/
public class FastJsonObjMain { /**
* @param args
*/
public static void main(String[] args) {
Map<String,User> userMap = new HashMap<String,User>();
User zsUser = new User();
zsUser.setId("zhangsan");
zsUser.setName("张三");
userMap.put("one", zsUser);
// 用户二
User lsUser = new User();
lsUser.setId("lisi");
lsUser.setName("李四");
userMap.put("two", lsUser); String jsonString = JSON.toJSONString(userMap);
System.out.println("Map to JSON -> ");
System.out.println(jsonString);
} }
输出内容:
Map to JSON ->
{"one":{"id":"zhangsan","name":"张三"},"two":{"id":"lisi","name":"李四"}}
FastJson 数组、List、Set、Map基本序列化与日期格式化的更多相关文章
- jackson、fastjson、kryo、protostuff等序列化工具性能对比
简介 实际项目中,我们经常需要使用序列化工具来存储和传输对象.目前用得比较多的序列化工具有:jackson.fastjson.kryo.protostuff.fst 等,本文将简单对比这几款工具序列化 ...
- JS数组filter()、map()、some()、every()、forEach()、lastIndexOf()、indexOf()实例
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat=&qu ...
- JQuery 操作数组 each、map、grep
Jquery中对数组的操作大致有一下几种形式:1.$.each( collection, callback(indexInArray, valueOfElement) )$.each()函数和$(se ...
- json序列化时间日期数据注意
通过json序列化时间日期格式数据的时候需要注意,不能直接序列化,我写了一个类,可以借用 import json from datetime import datetime,date a = {'na ...
- 使用fastjson将list、map转换成json,出现$ref
这是转换时出现的问题情况( map >> json ) 引用是通过"$ref"来表示的 引用 描述 "$ref":".." 上一 ...
- Java中让fastJson识别Colloction和Map中的泛型类
由于fastJson的高效性,最近采用fastJson来做序列化并存储数据,但出现了一个麻烦的问题,如果将Map<K,V>这样的类型序列化,反序列化就会不尽人意,有以下尝试: 使用JSON ...
- 处理数组的forEach map filter的兼容性
处理数组的forEach //forEach处理 if(!Array.prototype.forEach) { Array.prototype.forEach = function (callback ...
- scala 学习笔记(02) 元组Tuple、数组Array、Map、文件读写、网页抓取示例
package yjmyzz import java.io.PrintWriter import java.util.Date import scala.io.Source object ScalaA ...
- jQuery数组($.each,$.grep,$.map,$.merge,$.inArray,$.unique,$.makeArray)处理函数详解
1. $.each(array, [callback]) 遍历[常用] 解释: 不同于例遍jQuery对象的$().each()方法,此方法可用于例遍任何对象.回调函数拥有两个参数:第一个为对象的成员 ...
随机推荐
- 如何保障Web应用安全性
通过加密算法对关键数据进行加密 通过过滤器防御跨站脚本攻击XSS.跨域请求伪造CRSF和SQL注入 通过安全框架( Shiro.Spring Security )进行认证和授权 设置IP黑白名单来进行 ...
- es2015箭头函数的this
摘自https://www.cnblogs.com/chenxygx/p/6509564.html,谢谢博主的分享!
- flex下部固定高,上部不固定,而且超过内容要滚动
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&quo ...
- Java位运算符浅析
在学习源码中,发现有大量使用位运算符,这样做的目的是为了节约内存开销和加快计算效率. 位运算符,这个”位”代表这什么? 位:二进制位简称“位”,是二进制记数系统中表示小于2的整数的符号,一般用1或 0 ...
- 以resnet作为前置网络的ssd目标提取检测
http://blog.csdn.net/zhangjunbob/article/details/53119959
- usrp使用
首先打开linux 输入uhd_find_divice gqrx
- SpringBoot捕获全局异常
1.创建GloableExceptionAop类捕获全局异常 package com.cppdy.exception; import org.springframework.web.bind.anno ...
- WireShark Flow capture analysis
Wiresharkl流量分析 1.图示是对WiFi数据接口的80号端口进行数据捕获,设置混杂模式 过滤表达式设置: IP地址设置过滤 ip.src==191.168.1.102 ip.dst ...
- poj2513--并查集+欧拉路+字典树
经典好题,自己不知道哪里错了交上去是RE,可能是数组开的不好吧,字典树老碰到这种问题.. 先马上别人的代码,有空对拍看看 #include <cstdio> #include <cs ...
- 性能测试五十:Jmeter+Influxdb+Grafana实时数据展示系统搭建
如果用生成jtl文件再分析结果的方式的话,每一次请求就会往jtl里面写一条数据,在进行长时间的稳定性测试的时候,特别是当TPS很高的时候,写入的数据会非常的大,这个时候等稳定性测试完成,再对jtl进行 ...