上一篇写了一种二进制读写含多态的派生类的方法了,这次发散思路再写一种。
先写好派生类:
class a {
public:
int m;
a(int m1) {
m = m1;
}
virtual void MsgBox() {
cout << "It's a." << endl;
}
};
class b :public a {
public:
int n;
double n2;
b(int m=2,int o=3):a(m){
n = m;
n2 = o;
}
void MsgBox() {
cout << "It's b." << endl;
}
};
二进制写的方法例子:
int i = 0;
a* k = new b(8, 9);
ofstream outf("test1.dat", ios::out | ios::binary);
i = sizeof(b)-4;//减去头部虚表指针大小
outf.write((char *)&i, sizeof(int));
outf.write(((char *)k)+4, i);//省去虚表指针
outf.close();
二进制读的方法例子:
int i = 0;
a* m = new b(1,2);//仅作开辟空间用
ifstream outf("test1.dat", ios::in | ios::binary);
outf.read((char *)&i, sizeof(int));
outf.read(((char *)m)+4, i);跳过虚表指针写入
outf.close();
在读取之前的内存分布:

在读取之后的内存分布:

可见思路同上一篇,都是利用新对象的虚表指针替换旧的虚表指针,以实现读写后的多态。
不过第二种可以不写类的拷贝构造,默认构造与少声明对象,但代码不够直观。
本文介绍了一种使用二进制文件读写包含多态的派生类对象的方法,通过实例展示了如何避免虚表指针的复制,实现更高效的数据存储和读取。此方法适用于需要在不同程序间传递复杂类对象的场景。
666

被折叠的 条评论
为什么被折叠?



