序列化就是把
内存中的对象的状态信息,转换成
字节序列以便于存储(持久化)和网络传输。(网络传输和硬盘持久化,你没有一定的手段来进
行
辨别这些字节序列是什么东西,有什么信息,这些字节序列就是垃圾)。
反序列化就是将收到
字节序列或者是硬盘的持久化数据,转换成
内存中的对象。
为什么Hadoop基本类型还要定义序列化?
Hadoop在集群之间通信或者RPC调用时需要序列化,而且要求序列化要快,且体积要小,占用带宽小。
java的序列化机制占用大量计算开销,且序列化结果体积过大;它的引用机制也导致大文件不能被切分,浪费空间;此外,很难对其他语言进行扩展使
用;
java的反序列化过程每次都会构造新的对象,不能复用对象。
Hadoop定义了两个序列化相关接口
Writable和Comparable
WritableComparable接口相当于继承了上述两个接口的新接口
Public interface WritableComparable<T>
extends Writable,Comparable<T>
Writable和Comparable
WritableComparable接口相当于继承了上述两个接口的新接口
Public interface WritableComparable<T>
extends Writable,Comparable<T>