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()

相关内容

热门资讯

宠智灵打造宠物智能项圈AI解决... 转自:蚌埠新闻网在智能硬件加速发展的推动下,宠物智能项圈作为连接宠物与数字世界的关键载体正从简单的定...
数字经济ETF工银(56122... 7月11日,截止午间收盘,数字经济ETF工银(561220)涨0.68%,报1.036元,成交额37...
高中生跑腿半天赚16元倒欠千余... 转自:北京新闻广播 #3名高中生兼职跑腿没赚钱反而倒贴#...
升级训练基地功能 锤炼民兵专业... 转自:中国国防报四川省宜宾军分区升级训练基地功能 锤炼民兵专业技能本报讯 勾飞、记者杨晓霖报道:“岷...
业绩靓丽,药明康德罕见涨停,医... 昨夜,药明康德发布半年度业绩预告,营收208亿人民币,同比增长20.64%;净利润85.6亿,同比增...
鲁股观察 | 61.26亿元!... 转自:山东财经报道文 | 经济导报 段海涛杰瑞股份(002353.SZ)7月9日晚间公告称,全资子公...
ETF午评 | 稀土、大金融板... 格隆汇7月11日|A股三大指数早盘集体上涨,截至午盘,沪指涨1.05%,深成指涨0.94%,创业板指...
青春力量助力乡村振兴 长郡学子... 青春脚步量乡野,灼见真知话振兴!7月7日至11日,长郡中学高一第三大队150余名师生进驻长郡自贸临空...
意义重大!GE医疗北京基地迎来... 近日,在GE医疗北京影像设备制造基地(以下简称“GE医疗北京基地”),迎来了第3.5万台探测器的正式...
长图丨追火大同,越来越野 (转自:山西新闻网)