一例“msvc编译器O2优化触发的崩溃”的分析

本文分析了一起由MSVC编译器O2优化引起的栈不平衡崩溃问题,通过反汇编和实时调试,发现是由于调用约定不一致导致edi寄存器值变化。使用volatile关键字使得删除指针时从栈中获取,从而避免了崩溃。然而,只有将volatile关键字应用于指针变量并确保其存储在栈上,才能真正解决问题。
摘要由CSDN通过智能技术生成

栈不平衡与调用约定

1. 初步分析

某进程崩溃必现。
打开崩溃dmp,结合c++源代码,崩溃大致发生在某dll代码里的这句:SAFE_DELETE(pContentData);

En_HP_HandleResult CTcpOperation::OnClintReceive(HP_Client pSender, HP_CONNID dwConnID, const BYTE * pdata, int iLength)
{
        LOG_INFO(_T("Client OnReceive iLength is %d"), iLength);
        if (iLength == sizeof(STcpTransferData))
        {
                LPVOID pVoidTemp = nullptr;
                STcpTransferData cTransferData;
                memmove(&cTransferData, pdata, sizeof(STcpTransferData));

                if (CTcpOperation::GetInstance()->CheckAndSetData(ETransferType::SenddataLength, cTransferData, dwConnID, pVoidTemp))//单条数据总大小
                {
                        HP_Client_SetExtra(pSender, pVoidTemp);
                        LOG_INFO(_T("OnClintReceive new message set length"));
                        ret
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值