把类对象,在内存中按照一定的格式整合起来,拼成二进制串的过程就是序列化。
-
按一定格式:保证序列化后再取用可以知道各个字段的意思。
-
整合起来:对象在内存中可能是分散存储的
-
拼成二进制串:电脑中的数据都是二进制串。
序列化只是个抽象概念,具体实现要看实际情况。有时候序列化的实现就是将实例的内存直接发出去。不过这样做的时候需要被序列化的类满足POD,还不能有padding。
POD就保证了数据是紧密的,不会包含着运行相关的数据,例如指针(有指针的话,数据是分散在内存中存储的)(保存指针信息没有意义因为到接受方会失效),类型信息等。因为运行时的数据对于接收方来说说没有意义的。padding就是机器相关,为了不必要的麻烦和节省传输带宽,就不能包含padding。