平台崩溃之operator new异常(十八)-2010-7-12

本文记录了一次在7点30左右接到洪工保障时遇到的Userbreakpoint提示的异常情况,通过调用栈和断点调试的方式定位到HTX_Task_Base::enqueue方法中的ACE_NEW_RETURN处,并详细记录了异常发生时的上下文变量状态。
摘要由CSDN通过智能技术生成

7点30左右接到洪工保障,平台弹出User breakpoint提示框,当时调用栈如下:

MSVCRTD! 10211920()
MSVCRTD! 10211863()
MSVCRTD! 10211836()
MSVCRTD! 1020e1be()
ACED! 0052a95f()
ACED! 00533774()
ACED! 00533fd5()
ACED! 00533a26()
HTX_Task_Base::enqueue(CWrappedMsg<umxns::CUMXApp> * 0x314d9650, unsigned char 0) line 60 + 68 bytes
HTX_Dispatcher::handle_message_block(ACE_Message_Block * 0x314d9710) line 100 + 19 bytes
HTX_Task_Base::svc() line 103 + 17 bytes
ACED! 00585301()
ACED! 00585ab7()
ACED! 005859e4()
ACED! 004fa836()
MSVCRTD! 1020c323()
KERNEL32! 7c824829()

 

停在HTX_Task_Base::enqueue方法的ACE_NEW_RETURN处,代码如下:

int HTX_Task_Base::enqueue(CWrappedMsg<> *wm,bool preemptive) {
 ACE_Message_Block *mb = 0;
 ACE_NEW_RETURN(mb,ACE_Message_Block(sizeof(CWrappedMsg<>*)),0);
 memcpy(mb->wr_ptr(), &wm, sizeof(CWrappedMsg<>*));
 mb->wr_ptr(sizeof(CWrappedMsg<>*));
 
// static int msg_deadline[] = {1000,100,10,1}; /// MP_LOW,MP_NORMAL,MP_HIGH,MP_URGENT
// ACE_Time_Value tv;
// tv.set(msg_deadline[wm->msg->GetMsgPriority()-1]);
// ACE_Time_Value deadline(ACE_OS::gettimeofday()+tv);
// mb->msg_deadline_time(deadline);

// return msg_queue()->enqueue_prio(mb);
// return msg_queue()->enqueue_tail(mb);
 return preemptive ? msg_queue()->enqueue_head(mb) : msg_queue()->enqueue_tail(mb);
}

 

 

 

查看Output窗口未出现任何异常.

在ACE_NEW_RETURN的下一行设置端点,并观察上下文变量及地址,8点30分左右按下F5继续运行。在端点处观察变量发现是同一个

线程,从而证明出问题的线程没有异常退出,然后健康。

8点30左右继续运行平台(未重起)

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值