JAVA序列化与JSON数据之间的关系
创始人
2024-03-28 08:58:31
0

RPC、Http、TCP/IP、Socket之间的关系及定义

序列化

目的:
1、以某种存储形式使自定义对象持久化;
2、将对象从一个地方传递到另一个地方。
3、使程序更具维护性。

序列化:让其变成字符串等类型冻结
通俗讲,就是将代码数据冻结起来,打好包,使其不发生变化,数据持久化,所谓持久化,就是将代码数据以某种方式存储起来,常见的硬盘等,网络的传输过程也需要将数据序列化,写成字节流, 序列化:让其变成字符串等类型冻结

最常见举例:
JSON.stringify()将对象、数组转换成字符串    JSON.stristring(Object) 变成字符串

反序列化

反序列化:将字符串变为对象,然后拿到相关的方法和属性等变量数据。

最常见举例:
JSON.parse()【从一个字符串中解析出json对象】,就是以  key 和 value 形式出现
JSON.parse(Object)

序列化

是将对象的状态信息转换为可以存储或传输的形式的过程。在序列化期间,对象将其当前状态写入到临时或持久性存储区。之后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。

字节流

字节流是由字节组成的,字符流是由字符组成的. Java里字符由两个字节组成.字节流是最基本的,所有的InputStream和OutputStream的子类都是,主要用在处理二进制数据,它是按字节来处理的但实际中很多的数据是文本,又提出了字符流的概念,它是按虚拟机的encode来处理,也就是要进行字符集的转化。在从字节流转化为字符流时,实际上就是byte[]转化为String时,public String(byte bytes[], String charsetName)有一个关键的参数字符集编码,通常我们都省略了,那系统就用操作系统默认的long

序列化的实现方法

把一个Java对象写入到硬盘或者传输到网络上面的其它计算机,这时我们就需要自己去通过java把相应的对象写成转换成字节流。对于这种通用的操作,我们为什么不使用统一的格式呢?没错,这里就出现了java的序列化的概念。在Java的OutputStream类下面的子类ObjectOutputStream类就有对应的WriteObject(Object object) 其中要求对应的object实现了java的序列化的接口。
在使用tomcat开发JavaEE相关项目的时候,我们关闭tomcat后,相应的session中的对象就存储在了硬盘上,如果我们想要在tomcat重启的时能够从tomcat上面读取对应session中的内容,那么保存在session中的内容就必须实现相关的序列化操作,还有jdbc加载驱动用的就是反序列化,将字符串变为对象。

Java编程中的序列化

无序列化

类某些属性不需要序列化,序列化和反序列化实现了的对象序列化,但是可以发现,操作时是将整个对象的所有属性序列化,那么transient关键字可以将某些内容不需要保存,就可以通过transient关键字来定义:private transient String title;此时title属性无法被序列化

序列化操作

public class Book implements Serializable{//序列化类:java.ioObjectOutputStream讲对象变为指定的二进制数据private static final long serialVersionUID = 1L;private String title;private double price;public Book(String tit,double pri){this.title=tit;this.price=pri;}public String toString() {Map hashMap = new HashMap();hashMap.put("Computer base", "6.2");hashMap.put("Computer webpage",  "45.2");hashMap.put("Java", "105.2");hashMap.put("Andriod", "89.2");//第一种:使用keySet()方法遍历哈希表hashMap中的一些元素System.out.println("通过keySet()方法遍历key和value:");Set keys = hashMap.keySet();for (String key : keys) {String value= hashMap.get(key);System.out.println("BookName:"+ key + " ,BookPrice:" + value);}return "BookName:"+this.title+" ,BookPrice:"+this.price;}
}

反序列化操作

将二进制数据换回原对象,构造方法:ObjectInputStream(InputStream in),方法: Object readObject() 从 ObjectInputStream 读取对象

public class Serialization {public static File file = null;public static void main(String[] args) throws Exception, IOException {file = new File("serialize.doc");//序列化到指定的文本ObjectOutputStream oos=new ObjectOutputStream(new FileOutputStream(file));oos.writeObject(new Book("Java Development",45.3));     oos.flush();oos.close();file = new File("serialize.doc");//反序列化到指定的文本ObjectInputStream ois=new ObjectInputStream(new FileInputStream(file));Object obj=ois.readObject();Book book=(Book) obj;System.out.println("\n By using the byte stream serialization operation, "+ "we can see the following information:\n"+book);ois.close();}}

工作中什么时候用到序列化了?

1.使用Spring注解@ResponseBody
2.使用JSON框架(jackson、Gson、fastjson)等给前端返回json数据。

JSON
我们在后端将需要返回的数据通过json处理成json字符串后转为二进制在网络中传输,浏览器会解析为json字符串,进而我们可以再通过json将json字符串转换为对象。
json 是种很简洁的协议,但可惜的是,它只能传递基本的数型(int,long,string等)但不能传递byte类型
JSON(JavaScript Object Notation, JS对象简谱)是一种轻量级的数据交换格式。易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。它和xml一样都是一种数据交换格式。

JSON的应用之一

将结果进行String 序列化传给前台或者远程发送

import com.alibaba.fastjson.JSONObject;
某个接口的实现方法内JSONObject jObject = new JSONObject();jObject.put("result", "fail");。。。。。。
return jObject.toJSONString();

JSON的应用之二

json.stringify()和json.parse()

相关内容

热门资讯

网络技术展开型介绍(超详细) ♥️作者:小刘在这里 ♥️每天分享云计算网络运维课堂笔记,疫情之下&#x...
Git__本地分支与远程分支的... 文章目录前言1. 用git checkout命令关联2.用 git push命令关联3.用 git ...
LocalDateTime 的... 与 Date 相比 LocalDateTime 线程安全,因为所有字段都用了 fina...
C++ Primer笔记——l... 目录 一.lambda介绍 (一).总体介绍 (二...
Mac上安装和测试Kafka 1. 安装 默认会把zookeeper一起安装好 brew install kafka 安装日志&#...
@计算矩阵的特征值与特征向量 @计算矩阵的特征值与特征向量 文章目录 我们经常遇到一个问题就是如何计算一个矩阵的特征值和特征向...
Shell脚本编写 1 入门 1.1 脚本格式 脚本以#!/bin/bash开头(指定bash解析器&#x...
C/C++KTV点歌系统 C/C++KTV点歌系统 KTV点歌系统(版本1) 1 ...
重学c/c++之预处理 预定义符号 这些定义符号都是语言内置的 printf("%s\n",__FILE__);//绝对路...
C/C++数据结构课程设计[长... C/C++数据结构课程设计[长春理工大学计算机科学技术学院2022秋季学期] 长春理...