1.为什么需要序列化?
一般来说,“活的”对象只生存在内存里,关机断电就没有了。而且“活的”对象只能由本地的进程使用,不能被发送到网络上的另外一台计算机。 然而序列化可以存储“活的”对象,可以将“活的”对象发送到远程计算机。
2.什么是序列化
1.序列化:就是把内存中的对象,转换成字节序列(或其他数据传输协议)以便与存储(持久化)和网络传输。
2.反序列化:就是将收到字节序列(或其他数据传输协议)或者是硬盘的持久化数据,转换成内存中的对象。
3.为什么hadoop不用java的序列化
因为Java的序列化是一个重量级序列化框架(Serializable),一个对象被序列化后,会附带很多额外的信息(各种校验信息,Header,继承体系等),不便于在网络中高效传输。所以hadoop就开发了一套自己的序列化框架(Writable)!!
4.Hadoop序列化特点
1.紧凑 :高效使用存储空间
2.快速:读写数据的额外开销小。
3.可扩展:随着通信协议的升级而可升级
4.互操作:支持多语言的交互