现象:
调试时,退出程序引发中断,调用堆栈和线程窗口中点开中断的反汇编代码,有如下信息
CKxxxClient::`scalar deleting destructor'+3Fh (111E3DFh)
分析:
前一个版本是没有这个问题的,当前版本与前一版本不同的是: 类函数加上virtual声明,将部分功能抽象化为继承类;前一版本CKxxxClient由栈实例化的(声明一个全局的CKxxxClient对象),当前版本改变为new一个CKxxxClient继承类对象(为了根据不同的操作类型生成不同的继承对象),仅此而已
而明显地,肯定是代码中隐藏有内奸,还是揪出来的好
解决:
有事不决求度娘(:-) 谷神凡人不能接近), 没有找到有帮助的信息。实在没有头绪,不得已,祭出久不修炼了的删除大法,一段一段代码地删除,直至不再报错,然后一段一段地加,最后定位如下:
#pragma pack(1)
typedef struct _tagxxx {
union {
struct {
BYTE branch1:1,
branch2:1,
branch3:1,
branch4:1,
branch5:1,
branch6:1,
branch7:1,
branch8:1;
};
BYTE value;
}a1;
...
}Txxx;
....
粗看没有问题呀,经常这么用的,肿么了?但是,加上以下的push和pop之后,BUG马上消失了
#pragma pack(push, pck1s, 1) // n = 1, pushed to stack
#pragma pack(show) // C4810
#pragma pack(pop, pck1s) // stack popped
#pragma pack(show) // C4810
结论:
好习惯是#pragma push之后,要老实地跟上#pragma pop指令
调试时,退出程序引发中断,调用堆栈和线程窗口中点开中断的反汇编代码,有如下信息
CKxxxClient::`scalar deleting destructor'+3Fh (111E3DFh)
分析:
前一个版本是没有这个问题的,当前版本与前一版本不同的是: 类函数加上virtual声明,将部分功能抽象化为继承类;前一版本CKxxxClient由栈实例化的(声明一个全局的CKxxxClient对象),当前版本改变为new一个CKxxxClient继承类对象(为了根据不同的操作类型生成不同的继承对象),仅此而已
而明显地,肯定是代码中隐藏有内奸,还是揪出来的好
解决:
有事不决求度娘(:-) 谷神凡人不能接近), 没有找到有帮助的信息。实在没有头绪,不得已,祭出久不修炼了的删除大法,一段一段代码地删除,直至不再报错,然后一段一段地加,最后定位如下:
#pragma pack(1)
typedef struct _tagxxx {
union {
struct {
BYTE branch1:1,
branch2:1,
branch3:1,
branch4:1,
branch5:1,
branch6:1,
branch7:1,
branch8:1;
};
BYTE value;
}a1;
...
}Txxx;
....
粗看没有问题呀,经常这么用的,肿么了?但是,加上以下的push和pop之后,BUG马上消失了
#pragma pack(push, pck1s, 1) // n = 1, pushed to stack
#pragma pack(show) // C4810
#pragma pack(pop, pck1s) // stack popped
#pragma pack(show) // C4810
结论:
好习惯是#pragma push之后,要老实地跟上#pragma pop指令