По какой причине я получаю «Не абстрактный, не -.cctor -метод в интерфейсе»?

У меня очень странная проблема. У меня есть интерфейс, определенный в dll следующим образом:

public interface IKreator2
{
    string Name { get; set; }
    string Description { get; set; }

    INotifyPropertyChanged Settings { get; set; }

    InfiniRenderJob Job { get; set; }
    UserControl UI { get; set; }

    void Init();
    //void OnClose();
}

Если я свяжусь с этой dll в своем приложении WPF, отладчик выйдет из строя при загрузке (Внутренняя ошибка :Необработанное исключение в отладчике ::HandleIPCEvent, ID=0x246 ). Если я отлаживаю приложение с помощью «отладки неуправляемого кода», я получаю следующие ошибки:

  • Первое -случайное исключение по адресу 0x76977945 (KernelBase.dll )в InfiniRender.Host.exe :Исключение Microsoft C++ :EETypeLoadException в ячейке памяти 0x0029c5b8.
  • Первое -случайное исключение по адресу 0x76977945 (KernelBase.dll )в InfiniRender.Host.exe :Исключение Microsoft C++ :[возврат] в память адрес 0x00000000.
  • Возникло первое случайное исключение типа «System.TypeLoadException». в InfiniRender.Host.exe
  • Произошло необработанное исключение типа «System.TypeLoadException» в InfiniRender.Host.exe Дополнительная информация :Ничего абстрактного Nicht -.cctor -Methode in einer Schnittstelle.

На данный момент я абсолютно не понимаю, что происходит. Нет даже внедрения интерфейса, и ни один класс его не использует. Если я закомментирую метод "Init", все будет работать как положено. Любые идеи??

[РЕДАКТИРОВАТЬ] Это MSIL для метода инициализации интерфейса :

.method public hidebysig newslot virtual 
      instance void  Init() cil managed
{
// Code size       96 (0x60)
.maxstack  3
.locals init ([0] class [mscorlib]System.Exception CS$0$0__ex)
IL_0000:  ldsfld     class [NLog]NLog.Logger '<>z__LoggingImplementationDetails'::l14
IL_0005:  callvirt   instance bool [NLog]NLog.Logger::get_IsTraceEnabled()
IL_000a:  brfalse.s  IL_001b

IL_000c:  ldsfld     class [NLog]NLog.Logger '<>z__LoggingImplementationDetails'::l14
IL_0011:  ldstr      "Entering: InfiniRender.IKreator2.Init()"
IL_0016:  call       instance void [NLog]NLog.Logger::Trace(string)
.try
{
  IL_001b:  newobj     instance void [mscorlib]System.NotSupportedException::.ctor()
  IL_0020:  throw

  IL_0021:  ldsfld     class [NLog]NLog.Logger '<>z__LoggingImplementationDetails'::l14
  IL_0026:  callvirt   instance bool [NLog]NLog.Logger::get_IsTraceEnabled()
  IL_002b:  brfalse.s  IL_003c

  IL_002d:  ldsfld     class [NLog]NLog.Logger '<>z__LoggingImplementationDetails'::l14
  IL_0032:  ldstr      "Leaving: InfiniRender.IKreator2.Init()"
  IL_0037:  call       instance void [NLog]NLog.Logger::Trace(string)
  IL_003c:  leave.s    IL_005f

}  // end.try
catch [mscorlib]System.Exception 
{
  IL_003e:  ldsfld     class [NLog]NLog.Logger '<>z__LoggingImplementationDetails'::l14
  IL_0043:  callvirt   instance bool [NLog]NLog.Logger::get_IsWarnEnabled()
  IL_0048:  brfalse.s  IL_005d

  IL_004a:  stloc.0
  IL_004b:  ldsfld     class [NLog]NLog.Logger '<>z__LoggingImplementationDetails'::l14
  IL_0050:  ldstr      "An exception occurred:\n{0}"
  IL_0055:  ldloc.0
  IL_0056:  call       instance void [NLog]NLog.Logger::Warn(string,
                                                             object)
  IL_005b:  rethrow
  IL_005d:  leave.s    IL_005f

}  // end handler
IL_005f:  ret
} // end of method IKreator2::Init

. Мне кажется, что виноват NLog? Никогда не было проблем с NLog до сегодняшнего дня...

6
задан MiFreidgeim SO-stop being evil 9 August 2012 в 11:42
поделиться