欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Netty序列化深入理解與使用

 更新時間:2022年08月01日 10:46:38   作者:kaico2018  
序列化 (Serialization)是將對象的狀態(tài)信息轉(zhuǎn)換為可以存儲或傳輸?shù)男问降倪^程。在序列化期間,對象將其當前狀態(tài)寫入到臨時或持久性存儲區(qū)。以后,可以通過從存儲區(qū)中讀取或反序列化對象的狀態(tài),重新創(chuàng)建該對象

序列化與反序列化

序列化:把對象轉(zhuǎn)換成字節(jié)的過程,稱為對象序列化

反序列化:把字節(jié)恢復(fù)成對象的過程,稱為反序列化

  • 對象的持久化概念:把字節(jié)保存的硬盤上永久的存放
  • 網(wǎng)絡(luò)傳輸對象概念:客戶端將對象序列化為字節(jié)(序列化),變成二進制的形式發(fā)送到服務(wù)器端端,服務(wù)器端接受到字節(jié)對象后,反序列化成對象

注意序列化的類必須要實現(xiàn) Serializable 接口, transient 修飾變量使得該變量不被序列化。

網(wǎng)絡(luò)傳輸過程中不能直接傳輸對象,TCP協(xié)議的底層是二進制。

序列化模式

1.對象持久化概念:將對象轉(zhuǎn)換成字節(jié),存放到硬盤或者是數(shù)據(jù)庫中

2. 網(wǎng)絡(luò)傳輸對象概念:客戶端將對象轉(zhuǎn)成字節(jié)的形式(序列化)、變成二進制的形式發(fā)送給服務(wù)器端,服務(wù)器端接受到字節(jié)之后,反序列化成對象(rpc 遠程通訊)。

其他對象序列化方式

1、將對象轉(zhuǎn)換成json類型,實現(xiàn)跨語言

客戶端將對象轉(zhuǎn)換程json類型,傳遞給服務(wù)器端序列化。

服務(wù)器端獲取到j(luò)son, 在將json轉(zhuǎn)換成對象反序列化。

2、Xml類型

一般比較重量級,一般只有銀行、保險公司使用這種方式。

3、ProtoBuf(谷歌第三方協(xié)議,谷歌自定義協(xié)議)

4、MessagePack

也屬于json里面的

使用json協(xié)議實現(xiàn)對象的傳輸

就是將對象轉(zhuǎn)換成json字符串進行傳輸。

MessagePack編碼器

它像JSON, 但是更快更小。

MessagePack是一種高效的二進制序列化格式。它允許您在JSON等多種語之間交換數(shù)據(jù),但它更快速更小巧。小整數(shù)被編碼為單個字節(jié),典型的短字符串除了字符串本身之外只需要一個額外的字節(jié)。

支持Python、Ruby、 Java、 C/C++ 等眾多語言。宣稱比Google Protocol Buffers還要快4倍。。

使用案例:

引入mave依賴:

<dependency>
    <groupId>org.msgpack</groupId>
    <artifactId>msgpack</artifactId>
    <version>0.6.12</version>
</dependency>

基本api使用:

 // 創(chuàng)建MessagePack
MessagePack messagePack = new MessagePack();
MsgEntity meite = new MsgEntity(UUID.randomUUID().toString(), "kaico學(xué)習(xí)");
// 序列化
byte[] bs = messagePack.write(meite);
Value read1 = messagePack.read(bs);
System.out.println(read1);
// 反序列化
MsgEntity read = messagePack.read(bs, MsgEntity.class);
System.out.println(read);

在Netty框架中使用

編碼器

public class MsgpackEncoder extends MessageToByteEncoder {
    /**
     * 對我們數(shù)據(jù)實現(xiàn)編碼
     *
     * @param channelHandlerContext
     * @param msg
     * @param byteBuf
     * @throws Exception
     */
    @Override
    protected void encode(ChannelHandlerContext channelHandlerContext, Object msg, ByteBuf byteBuf) throws Exception {
        MessagePack msgpack = new MessagePack();
        byteBuf.writeBytes(msgpack.write(msg));
    }
}

解碼器

public class MsgpackDecoder extends MessageToMessageDecoder<ByteBuf> {
    /**
     * 服務(wù)器解碼數(shù)據(jù)
     *
     * @param channelHandlerContext
     * @param byteBuf
     * @param list
     * @throws Exception
     */
    @Override
    protected void decode(ChannelHandlerContext channelHandlerContext, ByteBuf byteBuf, List<Object> list) throws Exception {
        final int length = byteBuf.readableBytes();
        byte[] b = new byte[length];
        byteBuf.getBytes(byteBuf.readerIndex(), b, 0, length);
        MessagePack msgpack = new MessagePack();
        list.add(msgpack.read(b));
    }
}

服務(wù)端使用

socketChannel.pipeline().addLast(new MsgpackDecoder());
socketChannel.pipeline().addLast(new ServerHandler());

客戶端使用

ch.pipeline().addLast(new MsgpackEncoder());
ch.pipeline().addLast(new ClientHandler());

到此這篇關(guān)于Netty序列化深入理解與使用的文章就介紹到這了,更多相關(guān)Netty序列化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解使用@RequestBody取POST方式的json字符串

    詳解使用@RequestBody取POST方式的json字符串

    這篇文章主要介紹了詳解使用@RequestBody取POST方式的json字符串,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • Java實現(xiàn)redis分布式鎖的三種方式

    Java實現(xiàn)redis分布式鎖的三種方式

    本文主要介紹了Java實現(xiàn)redis分布式鎖的三種方式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • Java?實戰(zhàn)項目之學(xué)生信息管理系統(tǒng)的實現(xiàn)流程

    Java?實戰(zhàn)項目之學(xué)生信息管理系統(tǒng)的實現(xiàn)流程

    讀萬卷書不如行萬里路,只學(xué)書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+SSM+jsp+mysql+maven實現(xiàn)學(xué)生信息管理系統(tǒng),大家可以在過程中查缺補漏,提升水平
    2021-11-11
  • Java關(guān)系操作符簡寫介紹

    Java關(guān)系操作符簡寫介紹

    下面小編就為大家?guī)硪黄狫ava關(guān)系操作符簡寫介紹。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • 在Java的Struts中判斷是否調(diào)用AJAX及用攔截器對其優(yōu)化

    在Java的Struts中判斷是否調(diào)用AJAX及用攔截器對其優(yōu)化

    這篇文章主要介紹了在Java的Struts中判斷是否調(diào)用AJAX及用攔截器對其優(yōu)化的方法,Struts框架是Java的SSH三大web開發(fā)框架之一,需要的朋友可以參考下
    2016-01-01
  • 在Java中操作Zookeeper的示例代碼詳解

    在Java中操作Zookeeper的示例代碼詳解

    這篇文章主要介紹了在Java中操作Zookeeper的示例代碼詳解,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • Springboot實現(xiàn)定時任務(wù)的4種方式舉例詳解

    Springboot實現(xiàn)定時任務(wù)的4種方式舉例詳解

    在我們開發(fā)項目過程中經(jīng)常需要定時任務(wù)來幫助我們來做一些內(nèi)容,下面這篇文章主要給大家介紹了關(guān)于Springboot實現(xiàn)定時任務(wù)的4種方式,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-01-01
  • Java線程池7個參數(shù)的含義

    Java線程池7個參數(shù)的含義

    這篇文章主要介紹了Java線程池7個參數(shù)的含義,所謂的線程池的?7?大參數(shù)是指,在使用?ThreadPoolExecutor?創(chuàng)建線程池時所設(shè)置的?7?個參數(shù),下文更多詳細內(nèi)容,需要的小伙伴可以參考一下
    2022-05-05
  • java類成員中的訪問級別淺析

    java類成員中的訪問級別淺析

    在本篇文章里小編給大家整理的是一篇關(guān)于java類成員中的訪問級別淺析內(nèi)容,有興趣的朋友們跟著學(xué)習(xí)下。
    2021-01-01
  • 詳解spring mvc(注解)上傳文件的簡單例子

    詳解spring mvc(注解)上傳文件的簡單例子

    本篇文章主要介紹了spring mvc(注解)上傳文件的簡單例子,具有一定的參考價值,有興趣的可以了解一下。
    2017-01-01

最新評論