Loader lock error

后端 未结 9 1557
孤独总比滥情好
孤独总比滥情好 2020-12-02 07:34

I am building on C++ dll, by writing code in C#.

I get an error, saying

LoaderLock was detected Message: Attempting managed execution insid

相关标签:
9条回答
  • 2020-12-02 08:13

    I recently got this error while creating an instance of an COM-Object written in native code:

    m_ComObject = Activator.CreateInstance(Type.GetTypeFromProgID("Fancy.McDancy"));
    

    This led to the described error. A "LoaderLock was detected"-Exception was thrown.

    I overcame this error by creating the object-instance in an extra thread:

    ThreadStart threadRef = new ThreadStart(delegate { m_ComObject = Activator.CreateInstance(Type.GetTypeFromProgID("Fancy.McDancy")); });
    Thread myThread = new Thread(threadRef);
    
    myThread.Start();
    myThread.Join(); // for synchronization
    
    0 讨论(0)
  • 2020-12-02 08:15

    UPDATE FOR .NET 4.0 AND MORE RECENT FRAMEWORKS

    This is an old question asked at the time of .Net 2.0, when support for mixed mode DLLs had serious initialization problems, prone to random deadlocks. As of .Net 4.0, the initialization of mixed mode DLLs has changed. Now there are two separate stages of initialization:

    1. Native initialization, called at the DLL's entry point, which includes native C++ run-time setup and execution of your DllMain method.
    2. Managed initialization, executed automatically by system loader.

    Since step #2 is performed outside of the Loader Lock, there is no deadlocks. The details are described at Initialization of Mixed Assemblies.

    To ensure your mixed mode assembly can be loaded from a native executable, the only thing you need to check is that DllMain method is declared as native code. #pragma unmanaged could help here:

    #pragma unmanaged
    
    BOOL APIENTRY DllMain(HMODULE hModule,
        DWORD  ul_reason_for_call,
        LPVOID lpReserved
        )
    {
        ... // your implementation here
    }
    

    It is also important that any code that DllMain might call directly or indirectly is also unmanaged. It makes sense to limit the type of functionality used by DllMain so you trace all code reachable from DllMain and ensure it is all compiled with #pragma unmanaged.

    Compiler helps a little by giving you warining C4747 if it detects that DllMain is not declared as unmanaged:

    1>  Generating Code...
    1>E:\src\mixedmodedll\dllmain.cpp : warning C4747: Calling managed 'DllMain': Managed code may not be run under loader lock, including the DLL entrypoint and calls reached from the DLL entrypoint
    

    However compiler won't generate any warnings if DllMain indirectly calls some other managed function, so you need to ensure that never happens, otherwise your application could deadlock randomly.

    0 讨论(0)
  • 2020-12-02 08:16

    I'm building a C++ CLR DLL (MSVS2015) that has to make calls into an unmanaged DLL and define unmanaged code. I use #pragma managed and #pragma unmanaged to control what mode it is in for a given area of the code.

    In my case I simply put #pragma unmanaged in front of my DllMain() and this solved the problem. It seemed to be thinking I wanted a managed version of DllMain().

    0 讨论(0)
提交回复
热议问题