Ho un'applicazione che blocca sul filo GUI, e ho usato WinDbg, insieme al "clrstack!" Il comando per ottenere questo traccia dello stack, ma io non riesco a capire dove si trova il problema Tutti questi metodi sembrano metodi quadro e nessuno è mio. Qualsiasi aiuto sarebbe molto apprezzato. Mi scuso per le lunghe codeHai bisogno di aiuto decifrare un C# traccia dello stack
OS Thread Id: 0x724 (0)
ESP EIP
0012ec88 7c90e4f4 [HelperMethodFrame_1OBJ: 0012ec88] System.Threading.WaitHandle.WaitOneNative(Microsoft.Win32.SafeHandles.SafeWaitHandle, UInt32, Boolean, Boolean)
0012ed34 792b687f System.Threading.WaitHandle.WaitOne(Int64, Boolean)
0012ed50 792b6835 System.Threading.WaitHandle.WaitOne(Int32, Boolean)
0012ed64 7b6f192f System.Windows.Forms.Control.WaitForWaitHandle(System.Threading.WaitHandle)
0012ed78 7ba2d0bb System.Windows.Forms.Control.MarshaledInvoke(System.Windows.Forms.Control, System.Delegate, System.Object[], Boolean)
0012ee18 7b6f328c System.Windows.Forms.Control.Invoke(System.Delegate, System.Object[])
0012ee4c 7b920717 System.Windows.Forms.WindowsFormsSynchronizationContext.Send(System.Threading.SendOrPostCallback, System.Object)
0012ee64 7a924102 Microsoft.Win32.SystemEvents+SystemEventInvokeInfo.Invoke(Boolean, System.Object[])
0012ee98 7a922833 Microsoft.Win32.SystemEvents.RaiseEvent(Boolean, System.Object, System.Object[])
0012eee4 7a923d2f Microsoft.Win32.SystemEvents.OnUserPreferenceChanged(Int32, IntPtr, IntPtr)
0012ef04 7aa8f184 Microsoft.Win32.SystemEvents.WindowProc(IntPtr, Int32, IntPtr, IntPtr)
0012ef08 003620a4 [InlinedCallFrame: 0012ef08]
0012f0cc 7b1d8cce System.Windows.Forms.Application+ComponentManager.System.Windows.Forms.UnsafeNativeMethods.IMsoComponentManager.FPushMessageLoop(Int32, Int32, Int32)
0012f168 7b1d8937 System.Windows.Forms.Application+ThreadContext.RunMessageLoopInner(Int32, System.Windows.Forms.ApplicationContext)
0012f1bc 7b1d8781 System.Windows.Forms.Application+ThreadContext.RunMessageLoop(Int32, System.Windows.Forms.ApplicationContext)
0012f1ec 7b195911 System.Windows.Forms.Application.Run(System.Windows.Forms.Form)
0012f200 00eb0ebb WinForms1.Program.Main()
0012f69c 79e71b4c [GCFrame: 0012f69c]
Stai tentando di modificare un oggetto GUI da un thread che non possiedono? Se è così potresti essere in esecuzione nel problema InvokeRequired. –
Per quanto ne so, non sto facendo nessuna operazione cross-thread. Penso che avrò un'estesa revisione del codice per rintracciarlo. –
Se qualcuno che sta leggendo questa discussione si occupa di questo problema essendo intermittente, un modo per forzare una repro è impostare una variabile di ambiente in un ciclo. Ecco un esempio di file .cmd che imposta una variabile d'ambiente a livello di sistema ogni ~ 5 secondi: codice: top setx.exe foo bar ping.exe -n 5 localhost> nul goto top – JohnW