Der folgende Codeausschnitt veranschaulicht einen Speicherverlust beim Öffnen von XPS-Dateien. Wenn Sie es ausführen und den Task-Manager beobachten, wird dieser größer und gibt keinen Speicher frei, bis die App beendet wird.Öffnen von XPS-Dokument in .Net verursacht einen Speicherverlust
'****** Konsolenanwendung BEGINNT.
Module Main
Const DefaultTestFilePath As String = "D:\Test.xps"
Const DefaultLoopRuns As Integer = 1000
Public Sub Main(ByVal Args As String())
Dim PathToTestXps As String = DefaultTestFilePath
Dim NumberOfLoops As Integer = DefaultLoopRuns
If (Args.Count >= 1) Then PathToTestXps = Args(0)
If (Args.Count >= 2) Then NumberOfLoops = CInt(Args(1))
Console.Clear()
Console.WriteLine("Start - {0}", GC.GetTotalMemory(True))
For LoopCount As Integer = 1 To NumberOfLoops
Console.CursorLeft = 0
Console.Write("Loop {0:d5}", LoopCount)
' The more complex the XPS document and the more loops, the more memory is lost.
Using XPSItem As New Windows.Xps.Packaging.XpsDocument(PathToTestXps, System.IO.FileAccess.Read)
Dim FixedDocSequence As Windows.Documents.FixedDocumentSequence
' This line leaks a chunk of memory each time, when commented out it does not.
FixedDocSequence = XPSItem.GetFixedDocumentSequence
End Using
Next
Console.WriteLine()
GC.Collect() ' This line has no effect, I think the memory that has leaked is unmanaged (C++ XPS internals).
Console.WriteLine("Complete - {0}", GC.GetTotalMemory(True))
Console.WriteLine("Loop complete but memory not released, will release when app exits (press a key to exit).")
Console.ReadKey()
End Sub
End Module
'****** Konsolenanwendung ENDE.
Der Grund dafür, dass es tausend Mal wiederholt wird, liegt darin, dass mein Code viele Dateien verarbeitet und Speicher schnell verliert, wodurch eine OutOfMemoryException erzwungen wird. Das Erzwingen der Speicherbereinigung funktioniert nicht (ich vermute, dass es sich um einen nicht verwalteten Speicherbereich in den XPS-internen Komponenten handelt).
Der Code war ursprünglich in einem anderen Thread und einer anderen Klasse, wurde jedoch vereinfacht.
Jede Hilfe sehr geschätzt.
Ryan
Jeder Beweis, dass dies ein echter Fehler ist? Wird es zusammen mit Repro-Schritten gemeldet? – Will
Der Beweis ist im Pudding, wie sie, laufen Sie und sehen Sie (kommentieren Sie das DirectCast oben, Sie werden ein Leck bekommen). Ich habe es nicht mit MS Connect angesprochen, aber mit MS Social (http://social.msdn.microsoft.com/Forums/en-US/windowsxps/thread/e31edefa-b07e-450d-8ab8-5a171ee8d4c1/?ppud= 4). –
Hatte das gleiche Problem heute. Danke, das hat es behoben! Übrigens, wie haben Sie diese Problemumgehung gefunden? Einfach herumprobieren? –