struct TestClass
{
int a;
double b;
};
这个结构体占用的内存的大小是16字节(windows下),它在内存里面按照double的字节大小对齐。
TestClass demo = {1, 1.1};
定义一个对象后,通过网络把这个demo对象发出去。
write(sockfd, &demo, sizeof(demo));
这样是发出去16个字节对吧?这样发出去的数据就包含了编译器字节对齐插进去的4个字节了吧?我的理解对吗?
如果把这个demo对象序列化为二进制的话是不是就是把demo里的int和double的值复制到一个缓冲区里,这样这个缓冲区的里面的值的长度就是12字节了(int + double)。这样的话,通过网络发送这个缓冲区里的数据的话就不包含字节对齐的值了吧,这就是序列化的意义吗?
求大神告诉我理解的对不对?不对的话我的哪些地方没有理解对呢?
1.write(sockfd, &demo, sizeof(demo));
这样发出去确实是16字节。
但是你要明白write函数本身是跟字节对齐没关的。write函数本身只知道从哪个地址开始,发送多少字节的内容,write函数本身可不知道你的demo是什么结构。之所以会发送16个字节,是因为sizeof(demo)算出来是16字节。
2.序列化是一些编程语言的库提供的,可以将数据映射为bytes用来存储或传输。反序列化就是从bytes重新进行加载还原。这两个过程是库本身提供的,库的开发者会确保这个过程在所有平台上都是可移植的。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。