序列化与反序列化

怼烎@ 2023-05-21 08:51 131阅读 0赞

一、概念

1、序列化

将数据结构转换称为二进制数据流或者文本流的过程。序列化后的数据方便在网络上传输和在硬盘上存储。

2、反序列化

与序列化相反,是将二进制数据流或者文本流转换称为易于处理和阅读的数据结构的过程。

3、序列化的意义

计算机往往是根据二进制来区分数据的,例如一个字节、两个字节、三个字节等等。由于在内存中或者磁盘上,或者平台的环境不同,为了方便数据在不同的地方能够具有相同的含义,我们需要将数据转换为一种大家都能识别的格式。二进制或者编码格式是大家都认同的方式,而序列化正好是将一种数据格式转换为二进制数据流的过程或者方法,那么该数据结构就能够在任何地方保持其原有的含义,这就是序列化的意义。

4、序列化的应用场景

(1)网络通讯(C/S):以字节方式在网络中传输数据;

(2)数据存储(例如文件,缓存);

二、kafka的序列化与反序列化

1、序列化

kafka序列化消息是在生产端,序列化后,消息才能网络传输。而构造KafkaProducer代码如下:

  1. Properties props = new Properties();
  2. props.put("bootstrap.servers", "ip:9092");
  3. props.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");
  4. props.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");
  5. kafkaProducer = new KafkaProducer<>(props);

属性key.serializervalue.serializer就是key和value指定的序列化方式。无论是key还是value序列化和反序列化实现都是一样的,所以接下来都只以value的序列化和反序列为例。

StringSerializer是内置的字符串序列化方式,核心源码如下:

  1. /**
  2. * String encoding defaults to UTF8 and can be customized by setting the property key.serializer.encoding,
  3. * value.serializer.encoding or serializer.encoding. The first two take precedence over the last.
  4. */
  5. public class StringSerializer implements Serializer<String> {
  6. private String encoding = "UTF8";
  7. ... ...
  8. @Override
  9. public byte[] serialize(String topic, String data) {
  10. try {
  11. // 如果数据为空,那么直接返回null即可
  12. if (data == null)
  13. return null;
  14. else
  15. // 否则将String序列化,即转为byte[]即可
  16. return data.getBytes(encoding);
  17. } catch (UnsupportedEncodingException e) {
  18. throw new SerializationException("Error when serializing string to byte[] due to unsupported encoding " + encoding);
  19. }
  20. }
  21. @Override
  22. public void close() {
  23. // nothing to do
  24. }
  25. }

2、反序列化

kafka反序列化消息是在消费端。由于网络传输过来的是byte[],只有反序列化后才能得到生产者发送的真实的消息内容。而构造KafkaConsumer代码如下:

  1. Properties props = new Properties();
  2. props.put("bootstrap.servers", "ip:9092");
  3. props.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
  4. props.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
  5. KafkaConsumer<String, String> kafkaConsumer = new KafkaConsumer<>(props);

属性key.deserializervalue.deserializer就是key和value指定的反序列化方式。

StringDeserializer是内置的字符串反序列化方式,核心源码如下:

  1. /**
  2. * String encoding defaults to UTF8 and can be customized by setting the property key.deserializer.encoding,
  3. * value.deserializer.encoding or deserializer.encoding. The first two take precedence over the last.
  4. */
  5. public class StringDeserializer implements Deserializer<String> {
  6. private String encoding = "UTF8";
  7. ... ...
  8. @Override
  9. public String deserialize(String topic, byte[] data) {
  10. try {
  11. // 如果数据为空,那么直接返回null即可
  12. if (data == null)
  13. return null;
  14. else
  15. // 否则将byte[]反序列化,即转为String即可
  16. return new String(data, encoding);
  17. } catch (UnsupportedEncodingException e) {
  18. throw new SerializationException("Error when deserializing byte[] to string due to unsupported encoding " + encoding);
  19. }
  20. }
  21. ... ...
  22. }

发表评论

表情:
评论列表 (有 0 条评论,131人围观)

还没有评论,来说两句吧...

相关阅读

    相关 序列序列

    一、概念 1、序列化 将数据结构转换称为二进制数据流或者文本流的过程。序列化后的数据方便在网络上传输和在硬盘上存储。 2、反序列化 与序列化相反,是将二进制

    相关 序列序列

    因为TCP/IP协议只支持字节数组的传输,不能直接传对象。对象序列化的结果一定是字节数组!当两个进程在进行远程通信时,彼此可以发送各种类型的数据。无论是何种类型的数据,都会以二

    相关 序列序列

    我们知道,和new创建对象,反射创建对象,序列化创建对象也是我们常用的一种对象创建方式,下面就详细的说一说序列化与反序列化。 一.序列化简述 为什么需要序列化与反序列

    相关 序列序列

    序列化:将对象转化为字节序列 反序列化:将字节序列转化为对象 序列化与反序列化的好处: 1. 进行远程通信传输对象 我们知道数据是以二进制的方式在网络上传输的

    相关 序列序列

    一、序列化的概念 序列化:首先,用日常生活中的例子来理解一下序列化。在我们日常生活中,运输一个整个的汽车总是不方便的,所以我们会把汽车拆开,当汽车变成一个个零件的时候,我们

    相关 序列序列

    概念 -------------------- 把对象的状态信息转换为字节序列的过程称为对象的序列化。 把字节序列恢复为对象的过程称为对象的反序列化。 对象的序列