Artikel-ID: 886385 - Geändert am: Freitag, 24. Februar 2012 - Version: 0.1

Speicherauslastung ist hoch, wenn Sie mehrere XmlSerializer Objekte in ASP erstellen.NET

SystemtippDieser Artikel bezieht sich auf ein anderes Betriebssystem als das von Ihnen verwendete. Für Sie möglicherweise nicht relevante Artikelinhalte wurden deaktiviert.
Alles erweitern | Alles schließen

Problembeschreibung

In Microsoft ASP.NET, steigt die Speicherauslastung unerwartet Wenn Sie mehrere erstellen XmlSerializer Objekte.

Ursache

Dieses Problem tritt auf, weil erstellt und in den Speicher wird, beim Erstellen geladen eine Assembly, Microsoft intermediate Language (MSIL) enthält, ein XmlSerializer Objekt. Die Assembly kann nicht entladen werden, ohne Entladen der Anwendungsdomäne, der es sich befindet. Wenn Sie daher mehrere erstellen XmlSerializer Objekte, bemerken Sie unerwartet hohe Speicherauslastung vorliegt.

Beispielsweise, wenn Sie den folgenden Konstruktor verwenden, um mehrere erstellen XmlSerializerObjekte, eine neue dynamische Assembly wird jedes Mal erstellt:
public void XmlSerializer( Type t, Type[] extraTypes)

Lösung

Um dieses Problem neu zu erstellen dynamischer Assemblys zu umgehen, verwenden Sie eine der folgenden Methoden:
  • Erstellen Sie eine Instanz der XmlSerializer Klasse, und setzen, die im Cache-Instanz mithilfe der Cache-APIs. Der folgende Code speichert beispielsweise für eine DLL-Datei mit dem Namen HighSchool, eine Instanz der XmlSerializer Klasse:
    XmlSerializer mySerializer = new XmlSerializer(typeof(HighSchool.MyClass), attrOverrides, extraTypes, root, "http://www.microsoft.com");
    Cache["HighSchoolSerializer"] = mySerializer 
    
    Verwenden Sie die Instanz von der XmlSerializer Klasse, die Sie in den Cache, anstatt eine neue zu erstellen XmlSerializer Objekt jedes Mal.
  • Verwenden Sie den folgenden XmlSerializer Klassenkonstruktoren. Diese Klassenkonstruktoren cache der Assemblys:
    In der.NET Framework, Version 1.0
     public XmlSerializer(Type);

    In der.NET Framework, Version 1.1
    public XmlSerializer(Type type);
    public XmlSerializer(Type type, string defaultNamespace); 
  • Deklarieren Sie die XmlSerializer Objekt ein statischer Member einer Klasse sein.

Informationsquellen

Weitere Informationen über die XmlSerializer Klasse und über die XmlSerializer Klasse Konstruktoren, besuchen Sie die folgenden Websites von Microsoft Developer Network (MSDN):

Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft .NET Framework 4.0
  • Microsoft .NET Framework 2.0
  • Microsoft .NET Framework 1.1
  • Microsoft .NET Framework 1.0
Keywords: 
kbtshoot kbprb kbmt KB886385 KbMtde
Maschinell übersetzter ArtikelMaschinell übersetzter Artikel
Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.
Den englischen Originalartikel können Sie über folgenden Link abrufen: 886385  (http://support.microsoft.com/kb/886385/en-us/ )
Microsoft stellt Ihnen die in der Knowledge Base angebotenen Artikel und Informationen als Service-Leistung zur Verfügung. Microsoft übernimmt keinerlei Gewährleistung dafür, dass die angebotenen Artikel und Informationen auch in Ihrer Einsatzumgebung die erwünschten Ergebnisse erzielen. Die Entscheidung darüber, ob und in welcher Form Sie die angebotenen Artikel und Informationen nutzen, liegt daher allein bei Ihnen. Mit Ausnahme der gesetzlichen Haftung für Vorsatz ist jede Haftung von Microsoft im Zusammenhang mit Ihrer Nutzung dieser Artikel oder Informationen ausgeschlossen.