CreateEx Causes Unhandled exception The activation

2019-06-19 12:44发布

itsAnalysisDataTable.CreateEx( WS_EX_CLIENTEDGE, AfxRegisterWndClass( CS_DBLCLKS, LoadCursor( NULL, IDC_ARROW ), (HBRUSH)::GetStockObject( NULL_BRUSH ), NULL ), "AnalysiysTable", WS_CHILD | WS_VISIBLE | WS_VSCROLL | WS_TABSTOP, dialogItemRect, this, IDC_ANALYSIS_DATA_TABLE );

This line has cost me two days of effort with no solution. itsAnalysisDataTable is a custom windows control having CWnd as its grand grand grand parent. The control has been successfully used in other paces without issues in our code. this is a CPropertyPage.

The problem I have is the line causes (and it does it every time) an Unhandled exception at 0x76f7fd5c in MyProduct (x64).exe: 0xC015000F: The activation context being deactivated is not the most recently activated one.

The exception occurs in 32-bit as well. I'm on Windows 7 x64, VS 2008.

What I have already tried:

  1. Enabling break on win32 exceptions in the debugger. No exception occurs (except first chance exceptions of which there are a lot in our code and have no effect)
  2. Recompiling the whole project
  3. Debugging the OnCreate handler for the control for exceptions.

Call Stack:

ntdll.dll!0000000076f7fd5c()    
[Frames below may be incorrect and/or missing, no symbols loaded for ntdll.dll] 
kernel32.dll!0000000076df42d3()     
mfc90d.dll!AfxDeactivateActCtx(unsigned long dwFlags=0, unsigned __int64 ulCookie=2077018657900210161)  Line 260 + 0x19 bytes   C++

Observations:

  1. If I skip the WS_CHILD flag the exception does not happen, but OnCreate is also not called on the control!
  2. If I ignore the exception and continue, the application works fine, the control also works fine.
  3. Calling AfxSetAmbientActCtx(FALSE) during app init suppresses the exception. But I think this is a hack, unless I can justify it.

5条回答
看我几分像从前
2楼-- · 2019-06-19 13:14

Had some mysterious crashes in a program that hosted IE along with several ActiveX controls.

Turns out an earlier division by zero (by one of the AX controls) eventually caused this exception and a subsequent Access Violation as well.

查看更多
smile是对你的礼貌
3楼-- · 2019-06-19 13:15

Calling AfxSetAmbientActCtx(FALSE) during app init suppresses the exception. But I think this is a hack, unless I can justify it.

The discussion on MS Connect 'MFC default exception handling causes problems with activation context' might help you justify the hack being a workaround suggestion from Microsoft.

查看更多
仙女界的扛把子
4楼-- · 2019-06-19 13:20

After hitting a lot of these, I've found the simple way to track down the root issue is to go to Debug -> Exceptions and enable ALL Thrown exceptions. Then you'll find there is some other exception that is firing, being silently caught, BUT messing up the activation context. Once you fix the first exception, the activation context exception won't happen.

查看更多
手持菜刀,她持情操
5楼-- · 2019-06-19 13:33

Had the same problem.

In my case i was reading a file from a path and I accidentally deleted that file. Putting the file back solved the issue.

查看更多
兄弟一词,经得起流年.
6楼-- · 2019-06-19 13:35

Turns out mine was due to an uninitialized member in the offending control class. Initializing the variable in the constructor fixed the issue. So I did not have to resort to AfxSetAmbientActCtx(FALSE)

查看更多
登录 后发表回答