FileNotFoundException для mscorlib.XmlSerializers.DLL, который не существует - PullRequest
12 голосов
/ 15 августа 2008

Я использую XmlSerializer для десериализации определенного типа в mscorelib.dll

XmlSerializer ser = new XmlSerializer( typeof( [.Net type in System] ) );
return ([.Net type in System]) ser.Deserialize( new StringReader( xmlValue ) );

Это выдает пойманное FileNotFoundException при загрузке сборки:

"Не удалось загрузить файл или сборку «mscorlib.XmlSerializers, Версия = 2.0.0.0, Культура = нейтральная, PublicKeyToken = b77a5c561934e089 'или одна из его зависимостей. Система не могу найти указанный файл. "

FusionLog:

=== Pre-bind state information ===
LOG: User = ###
LOG: DisplayName = mscorlib.XmlSerializers, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089, processorArchitecture=x86
 (Fully-specified)
LOG: Appbase = file:///C:/localdir
LOG: Initial PrivatePath = NULL
Calling assembly : System.Xml, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089.
===
LOG: This bind starts in default load context.
LOG: Using application configuration file: C:\localdir\bin\Debug\appname.vshost.exe.Config
LOG: Using machine configuration file from c:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\config\machine.config.
LOG: Post-policy reference: mscorlib.XmlSerializers, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089, processorArchitecture=x86
LOG: Attempting download of new URL file:///C:/localdir/bin/Debug/mscorlib.XmlSerializers.DLL.
LOG: Attempting download of new URL file:///C:/localdir/bin/Debug/mscorlib.XmlSerializers/mscorlib.XmlSerializers.DLL.
LOG: Attempting download of new URL file:///C:/localdir/bin/Debug/mscorlib.XmlSerializers.EXE.
LOG: Attempting download of new URL file:///C:/localdir/bin/Debug/mscorlib.XmlSerializers/mscorlib.XmlSerializers.EXE.

Насколько я знаю, mscorlib.XmlSerializers.DLL не существует, я думаю, что имя DLL было автоматически сгенерировано .Net в поисках сериализатора.

У вас есть возможность создать myApplication.XmlSerializers.DLL при компиляции для оптимизации сериализации, поэтому я предполагаю, что это часть проверки инфраструктуры на это.

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

Есть идеи, как этого избежать или ускорить?

Ответы [ 3 ]

4 голосов
/ 05 июня 2009

Хорошо, я столкнулся с этой проблемой и нашел решение, специфичное для моей области.

Это произошло из-за того, что я пытался сериализовать список в XML-документ (файл) без корневого атрибута XML. После добавления следующих файлов ошибка исчезает.

XmlRootAttribute rootAttribute = new XmlRootAttribute();
rootAttribute.ElementName = "SomeRootName";
rootAttribute.IsNullable = true;

Не знаю, исправит ли это вашу проблему, но исправила мою.

4 голосов
/ 15 августа 2008

Задержка вызвана тем, что, не сумев найти нестандартный dll-сериализатор, система на лету создает эквивалентный код (который занимает очень много времени).

Чтобы избежать задержки, нужно, чтобы система собрала DLL и удостоверилась, что она доступна для .EXE - пробовали ли вы это?

2 голосов
/ 15 августа 2008

Я догадываюсь сейчас. но:

  1. Система может генерировать сериализатор для всего mscorlib, который может быть очень медленным.
  2. Возможно, вы могли бы избежать этого, обернув тип системы в свой собственный тип и сериализовав его вместо этого - тогда вы получите сериализатор для вашей собственной сборки.
  3. Возможно, вы сможете собрать сериализатор для mscorlib с помощью sgen.exe, который был старым способом создания dll-сериализатора до его интеграции в VS.
...