ArcGIS Engine二次开发中有关内存泄漏异常的解决方法

  • Post author:
  • Post category:其他


在ArcGIS Engine二次开发过程中,.NET框架下,类库是经常被提及和使用的一类技术。而在类库的使用过程中,也经常会碰到内存方面的问题。尤其在COM编程环境下,非托管类的内存管理变的非常重要。现不管在.NET下VS如何进行管理的,我只就在AE中遇到的问题及如何解决的做以下阐述。

NET开发中,引用COM对象主要是通过RCW(Runtime Callable Wrappers)机制来实现的(有点类似于代理模式)。对于COM对象的释放,GC(.NET下的垃圾收集器)表现得有点无能为力,因此必须在程序中显示释放COM对象占用的资源,否则将会出现一些意想不到的错误。比如重复地从Personal GeoDataBase中打开GeoDataBase Cursors而又没有及时释放,将会引发“No more tables can be opened.”其它情形中,你可能会发现应用程序退出时,COM对象依然在内存中引用。比如StyleGallery如果没有显示释放,在应用程序退出时就会引发错误。这种情况下,我们可以用


Marshal.ReleaseComObject()

来释放COM对象。


例如:System.Runtime.InteropServices.Marshal.ReleaseComObject(featureCursor)。


而遇到“0xC0000005错误”这样的内存错误,是由于加载license的AoInitialize必须在所有AE的COM对象之前释放,在类库必须显示的释放。要使用


AOUninitialize.Shutdown



()

来释放。此函数放在你退出类库的时候调用即可解决这一错误。


这是我个人的一些开发体会,如有不妥,请批评指正!