结构体版本兼容问题

问题描述如下,有一个结构体

struct InstallInfo
{
int nFileSize; //安装包大小
LPCWSTR lpszMd5; //安装包md5
LPCWSTR lpszVersion; //安装包的版本号

};


升级exe会去加载一个dll,在dll中获取InstallInfo结构体成员。由于升级的新需求,需要从dll中获取安装包的更新信息,因此扩展上述的结构体,增加一个成员lpszUpdateInfo,如下所示:
struct InstallInfo
{
int nFileSize;//安装包大小
LPCWSTR lpszMd5;//安装包md5
LPCWSTR lpszUpdateInfo; //安装包的更新信息
LPCWSTR lpszVersion; //安装包的版本号
};

如果新的exe去访问旧的dll。此时,就会出现字段错位的bug。新的InstallInfo里面的内存布局是:

nFileSize:安装包大小

lpszMd5:安装包md5

lpszUpdateInfo:安装包的更新信息

lpszVersion:安装包的版本号


而旧的InstallInfo里面的内存布局是:

nFileSize:安装包大小

lpszMd5:安装包md5

lpszVersion:安装包的版本号


当新的exe(新的InstallInfo)去访问旧的dll(旧的InstallInfo)时,获取到的lpszUpdateInfo字段将会被错误赋值成lpszVersion,从而造成bug。


正确的做法是后面扩展增加的字段应该位于结构体的后面,如下所示:

struct InstallInfo
{
int nFileSize;//安装包大小
LPCWSTR lpszMd5;//安装包md5
LPCWSTR lpszVersion; //安装包的版本号
LPCWSTR lpszUpdateInfo; //安装包的更新信息
};

这时的内存布局是:

nFileSize:安装包大小

lpszMd5:安装包md5

lpszVersion:安装包的版本号

lpszUpdateInfo:安装包的更新信息

此时用新的exe去访问旧的dll,就不会出现错误问题了。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值