Visual Studio зависает при вызове GetThreadWaitChain WCT

Я пробую WCT и хочу вызвать GetThreadWaitChain, у меня было несколько предыдущих вопросов по этой теме, но недавно у меня было странное поведение. Когда я вызываю функцию GetThreadWaitChain, моя Visual Studio зависает с подсказкой:

vhost32.exe перестал работать

Выходное сообщение окна:

The program '[9068] testWCT.vshost.exe' has exited with code -1073740940 (0xc0000374).

Каждый раз, когда я добираюсь до этой функции, моя визуальная студия зависает...

Документация GetThreadWaitChain:

https://msdn.microsoft.com/en-us/library/windows/desktop/ms679364(v=vs.85).aspx

Это мой код:

internal void CollectWaitInformation(ClrThread thread)
{
    var g_WctHandle = OpenThreadWaitChainSession(0, 0);

    uint threadID = thread.OSThreadId;

    WAITCHAIN_NODE_INFO[] NodeInfoArray = new WAITCHAIN_NODE_INFO[16];


    int isCycle = 0;
    int count = 16;

    // Make a synchronous WCT call to retrieve the wait chain.
    bool result = GetThreadWaitChain(g_WctHandle,
                            IntPtr.Zero,
                            WCTP_GETINFO_ALL_FLAGS,
                            threadID, ref count, NodeInfoArray, out isCycle);

    if (!result)
    {
        //error
    }

    //Finaly ...
    CloseSession(g_WctHandle);
}

[DllImport("Advapi32.dll")]
public static extern IntPtr OpenThreadWaitChainSession(OpenThreadChainFlags Flags, DWORD callback);

[DllImport("Advapi32.dll")]
public static extern bool GetThreadWaitChain(
    IntPtr WctHandle,
    IntPtr Context,
    UInt32 Flags,
    uint ThreadId,
    ref int NodeCount,
    [MarshalAs(UnmanagedType.LPArray, SizeParamIndex = 4)]
    [In, Out]
    WAITCHAIN_NODE_INFO[] NodeInfoArray,
    out int IsCycle
);

[StructLayout(LayoutKind.Sequential)]
public struct WAITCHAIN_NODE_INFO
{
    public WCT_OBJECT_TYPE ObjectType;
    public WCT_OBJECT_STATUS ObjectStatus;

    public struct LockObject
    {
        string ObjectName;
        LARGE_INTEGER Timeout;
        BOOL Alertable;
    }
    public struct ThreadObject
    {
        DWORD ProcessId;
        DWORD ThreadId;
        DWORD WaitTime;
        DWORD ContextSwitches;
    }
}

}

Я пытался запустить код C++ в том же процессе, который я взял из MSDN: https://msdn.microsoft.com/en-us/library/windows/desktop/ms681418(v=vs.85).aspx

И все, что у меня есть, это: ошибка 0x57 во всех потоках в результате. Что является ERROR_INVALID_PARAMETER в соответствии с MSDN:

https://msdn.microsoft.com/en-us/library/windows/desktop/ms681382(v=vs.85).aspx

Что странно, потому что я не изменил код С++.

Предыдущий вопрос по той же теме: Вызов WCT GetThreadWaitChain всегда возвращает false


person Pavel Durov    schedule 10.12.2015    source источник
comment
0xc0000374 — это код ошибки повреждения кучи. В этом коде много повреждений памяти, ваше объявление WAITCHAIN_NODE_INFO неточно и слишком мало. Объявление структуры, содержащей объединение со строкой, не очень интересно, вместо этого сделайте это в проекте C++/CLI.   -  person Hans Passant    schedule 12.12.2015
comment
Откуда у вас ошибка 0xc0000374?   -  person Pavel Durov    schedule 13.12.2015
comment
Вы разместили это, код выхода процесса, который завершается ОС, является кодом исключения.   -  person Hans Passant    schedule 13.12.2015
comment
Впервые я увидел, как повреждение кучи сборщика мусора приводит к ошибке 0xc0000374. Обычно это приводит к ExecutionEngineException. Должно быть новое поведение .NET 4.6.x. Ну, один для книги рекордов.   -  person Hans Passant    schedule 14.12.2015


Ответы (1)


Я неправильно объявил структуру WAITCHAIN_NODE_INFO (мой союз был неправильным), это исходная структура:

https://msdn.microsoft.com/en-us/library/windows/desktop/ms681422(v=vs.85).aspx

Как только я объявил это правильным, повреждение кучи прекратилось, и все заработало...

person Pavel Durov    schedule 14.12.2015