保存PDF文档似乎在内存VB.NET中保留了引用

问题描述

|| 我有一个VB.NET用户控件,该控件保存PDF文档,然后将其显示在WebBrowser控件中。代码如下:
Using myPdfDoc As New FileStream(fileName,FileMode.Create)
    Dim byt As Byte() = comLib.GetData();
    If Not byt Is Nothing Then                        
        myPdfDoc.Write(byt,byt.Length)
        myPdfDoc.Flush()
        myPdfDoc.Close()

        webBrowserCtl.Navigate(fileName)
    End If
End Using
comLib是一个用VB6编写的COM互操作库,用于获取相关数据。 据我所知,此代码保留了对PDF文档的引用(因为程序完成时VB.NET不会关闭)。我发现这篇文章似乎暗示Adobe无法对其进行适当的清理,但实施其建议的更改似乎无济于事。 为什么我会得到这种行为?在VB6中,程序无法正常关闭始终是由于未清除流浪对象引用造成的。在VB.NET中仍然如此吗?如果是这样,我该怎么做以确定哪个对象,或者为什么会发生这种情况?     

解决方法

我将把它分开:读取数据,写入数据和查看数据:
Dim byt As Byte() = Nothing
Try
  byt = comLib.GetData()
Finally
  If Not comLib Is Nothing Then
    Marshal.ReleaseComObject(comLib)
  End If
End Try

If Not byt Is Nothing Then
  Using myPdfDoc As New FileStream(fileName,FileMode.Create)
    myPdfDoc.Write(byt,byt.Length)
  End Using

  Using webBrowserCtl As New WebBrowser()
    webBrowserCtl.Navigate(fileName)      
  End Using
End If  
最终中的Marshal.ReleaseComObject调用可确保始终减少引用计数。冲洗和关闭不是必需的,因为“处置”将始终执行此操作。 WebBrowser控件实现IDisposable,因此我也使用了Using块。     ,您正在做的事情比我过去做的要复杂。但是我可以告诉您,.NET中的PDF字节对象可以占用大量内存(即使已处置)。我建议在文件服务器上使用临时文件(在运行Web服务器的计算机上的实际目录中)。而不是将对象保留在内存中。我知道程序集PDFSharp具有一些可以使用的良好(免费)代码。但是我不知道什么会阻止您的程序退出。哥们,祝你好运。 PS:您可能想尝试自行调用垃圾收集器。并且您应该能够在Visual Studio中看到您的线程。当您附加到w3wp.exe(Windows 7中为IIS 7进程)进程时,将获得一个上下文菜单(Debug-> Windows-> Threads)。虽然我不知道COM线程是否会显示在其中。     

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...