上一篇写了一种二进制读写含多态的派生类的方法了,这次发散思路再写一种。
先写好派生类:
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();
在读取之前的内存分布:
在读取之后的内存分布:
可见思路同上一篇,都是利用新对象的虚表指针替换旧的虚表指针,以实现读写后的多态。
不过第二种可以不写类的拷贝构造,默认构造与少声明对象,但代码不够直观。