1、序列化和反序列化
序列化指的是将一个内存对象转化成一串字节数据(存储在一个字节数组中),可用于保存到本地文件或网络传输。
反序列化就是将字节数据还原成内存对象,能够轻松地存储和数据传输
我们的系统大多是小端系统,而一般在网络传输中却规定使用大端传输;
主机字节序=小端字节序(高位字节存储在内存高位地址);网络字节序=大端字节序。发送端总是把发送的数据转化为大端字节序然后发送。接收端根据自身选择是否转化。
12 00 00 00 0c 小端=内存中低位字节在前 0c 00 00 00内存
/*移位之后ByteArray中前四个字节存的便是00 00 00 0c*/
ByteArray[0] = s.id>>24;
ByteArray[1] = s.id>>16;
ByteArray[2] = s.id>>8;
ByteArray[3] = s.id;
接收端
s.id += ByteArray[0]<<24;
s.id += ByteArray[1]<<16;
s.id += ByteArray[2]<<8;
s.id += ByteArray[3];
序列化优点:
- 网络传输方面的便捷性、灵活性;
- 生成一个数据量大,算法复杂的数据结构可能会很久,可以通过序列化技术把这些数据存到磁盘上,下次执行的时候只需要从磁盘上读取对象的数据,花费读取一个文件的时间,节省开发时间。