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:
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:
Does anyone have any idea what specifically could cause this issue with "...calls to specific APIs..."?