Search code examples
c#wpfvisual-studiodllvshost32

Any idea what can cause "vshost32.exe has stopped working" in Visual Studio 2013?


A C# WPF application I am working on contains many calls to an unmanaged external DLL. All calls to the DLL work as expected when running the application normally (i.e. outside the Visual Studio debugger). However when debugging from within Visual Studio 2013, a call to one specific method in the DLL crashes the application:

vshost32.exe has stopped working

This is how I import the method:

[DllImport("Client.dll", CallingConvention = CallingConvention.Cdecl)]
private static extern string ClientGetVersion();

...and this is how I call the DLL method:

try
{
  version = ClientGetVersion();
}
catch (Exception ex)
{
  // Error handling omitted for clarity...
}

It appears that Visual Studio uses the vshost32.exe process to host applications during a debugging session (VSHOST - the Hosting Process). Furthermore, "Calls to certain APIs can be affected when the hosting process is enabled. In these cases, it is necessary to disable the hosting process to return the correct results." (See the MSDN article How to: Disable the Hosting Process). Disabling the "Enable the Visual Studio hosting process" option in Project > Properties... > Debug, as shown below, does indeed fix the problem:

enter image description here

Does anyone have any idea what specifically could cause this issue with "...calls to specific APIs..."?


Solution

  • The vshost32.exe error is caused by an incorrect DllImport statement - the return type of the external DLL cannot be string, it must be IntPtr.

    Here is the corrected code:

    [DllImport("Client.dll", CallingConvention = CallingConvention.Cdecl)]
    private static extern IntPtr ClientGetVersion();
    

    ...and this is the revised call to the DLL method:

    string version;
    
    try
    {
      version = Marshal.PtrToStringAnsi(ClientGetVersion());
    
    }
    catch (Exception ex)
    {
      // Error handling omitted for clarity...
    }
    

    Thanks to @HansPassant for the answer.