什么可能导致mscorwks的访问冲突!ThreadpoolMgr :: FireTimers?

时间:2011-12-01 22:46:29

标签: .net windbg threadpool sos mscorwks.dll

以下访问冲突每隔几天就会使我的应用程序崩溃。可能导致这种情况的原因是什么?

(80c.f28): Access violation - code c0000005 (first/second chance not available)
eax=d628f91d ebx=29d706e3 ecx=29d706e3 edx=0bd2feb8 esi=00000000 edi=00000000
eip=79fd897a esp=0bd2feb8 ebp=0bd2ff34 iopl=0         nv up ei ng nz ac pe cy
cs=001b  ss=0023  ds=0023 es=0023  fs=003b  gs=0000             efl=00010297
mscorwks!ThreadpoolMgr::FireTimers+0x8d:
79fd897a 8b3f            mov    edi,dword ptr [edi]  ds:0023:00000000=????????

这是stacktrace

0:011> kb
ChildEBP RetAddr  Args to Child              
0bd2ff34 79fd8a38 0bd2ff9c 79f7759b 2fb73db5 mscorwks!ThreadpoolMgr::FireTimers+0x8d
0bd2ffa8 79fd88ef 00000003 0bd2ffec 7c80b713 mscorwks!ThreadpoolMgr::TimerThreadFire+0x64
0bd2ffb4 7c80b713 0012eb4c 00000010 00000003 mscorwks!ThreadpoolMgr::TimerThreadStart+0x57
0bd2ffec 00000000 79fd8897 0012eb4c 00000000 kernel32!BaseThreadStart+0x37

这是我的版本信息

0:011> !EEVersion
2.0.50727.3053 retail
Server mode with 4 gc heaps
SOS Version: 2.0.50727.3625 retail build

1 个答案:

答案 0 :(得分:0)

c0000005异常通常是内存异常。您正在尝试访问内核空间中的内存,或者您没有内存区域的权限。遗憾的是,您提供的信息不足以进一步提供帮助。至少你应该提供堆栈跟踪,更好地输出'analyze -v'。

查看最后一个汇编指令,我可以看到它试图复制地址0处的数据,所以这个异常只是由于尝试取消引用地址0而引起的。