7.zookeeper原理解析-序列化之底层通信数据封装与操作
来源:互联网 发布:中国企业数据库 编辑:程序博客网 时间:2024/06/05 23:56
=====================================斩秋|http://blog.csdn.net/quhongwei_zhanqiu=======================================
BinaryInputArchive& BinaryOutputArchive底层通信数据封装与操作
BinaryInputArchive是对于DataInput的封装,用于处理基于zookeeper协议的底层数据,其实是从DataInputStream输入中读取数据。
BinaryOutputArchive是对于DataOutput的封装,根据zookeeper协议将数据写入到DataOutputStream中去。
1. 读取int, boolean基本数据类型直接代理给DataInput执行
写入int, boolean基本数据类型直接代理给DataOutput执行
2. 读取String和Buffer是,BinaryInputArchive根据Zookeeper协议做了处理
1) 读取四个字节int值表示读取数据内容的大小
2) 根据数据大小构建一个byte数组
3) 将DataInput的数据读取到字节数组中
写入String和Buffer是,BinaryOutputArchive根据Zookeeper协议做了处理
1) 写入四个字节int值表示写入数据内容的大小, 如果写入数据为null,值为-1
2)将数据转为字节数组,写入DataOutput中3. 读取复杂的数据对象,Zookeeper底层传输的对象都需要实现Record接口,readRecord方法,会代理给Record进行反序列化
写入复杂的数据对象,Zookeeper底层传输的对象都需要实现Record接口writeRecord方法,会代理给Record进行序列化
4. 对于Record对象中持有集合对象(当然能够序列化与反序列化,集合中的元素必须也实现Record):
BinaryInputArchive提供startVector
1) 读取四个字节的int数,表示集合的大小
2) 构建一个BinaryIndex对象返回
BinaryOutputArchive提供startVector
向DataOutput数据流中写入集合大小,如果为null值为-1
5. BinaryInputArchive对象的内部类BinaryIndex作用,主要是用来计数集合对象的反序列话的
Record是zookeepr底层通信数据序列化与反序列化统一接口,
=====================================斩秋|http://blog.csdn.net/quhongwei_zhanqiu=======================================
- 7.zookeeper原理解析-序列化之底层通信数据封装与操作
- Zookeeper系列(二十二)Zookeeper原理解析之序列化之底层通信数据封装与操作和Record接口
- 8.zookeeper原理解析-序列化之Record接口
- 1.zookeeper原理解析-数据存储之Zookeeper内存结构
- Zookeeper系列(十五)Zookeeper原理解析之数据存储之Zookeeper内存结构
- 1.zookeeper原理解析-数据存储之Zookeeper内存结构(zookeeper系列文章)
- 2.zookeeper原理解析-数据存储之Snapshot
- 3.zookeeper原理解析-数据存储之TxnLog事务日志
- 4.zookeeper原理解析-数据存储之FileTxnLog& FileTxnSnapLog工具
- 5.zookeeper原理解析-数据存储之ZKDatabase
- 11.zookeeper原理解析-选举之数据同步
- Zookeeper系列(十七)Zookeeper原理解析之数据存储之Snapshot
- Zookeeper系列(十八)Zookeeper原理解析之数据存储之TxnLog事务日志
- Zookeeper系列(十九)Zookeeper原理解析之数据存储之FileTxnLog& FileTxnSnapLog工具类
- Zookeeper系列(二十)Zookeeper原理解析之数据存储之ZKDatabase
- Zookeeper系列(二十一)Zookeeper原理解析之数据存储小结
- xml json 数据封装 传递(序列化) 解析
- IOS 底层封装Block动画的原理解析
- Android 你应该知道的学习资源 进阶之路贵在坚持
- PHP mySQL编码
- ZOJ 3878 Convert QWERTY to Dvorak
- java 二分法查找实现
- sphinx支持中文检索(安装coreseek)
- 7.zookeeper原理解析-序列化之底层通信数据封装与操作
- android-ListView(1)-listview概览
- 设计初学常犯的错误
- sphinx mysql 增量索引
- 学习ASP.NET MVC5框架揭秘笔记-IIS/ASP.NET管道(一)
- javascript instanceof
- list排序,如果A字段相同,则以B字段进行排序
- 数据库设计中关于数据类型的优化
- 金士顿U盘在我的电脑中无法显示的方法