问题描述如下,有一个结构体
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:安装包的更新信息 |