AE释放打开资源

        今天在用AE操作mdb数据库时,发现程序运行完毕,去打开mdb文件时总提示“文件已在使用中”,且ldb文件也无法删除。找了资料是因为打开MDB数据库操作后没有及时释放资源。ae的com对象是需要释放的,不然就可能会锁住一些基础设备(如mdb文件等)。

释放资源也就一句话System.Runtime.InteropServices.Marshal.ReleaseComObject(object o)。甚至我把每个新建的AE对象都逐步释放了,可依旧提示“文件已在使用中”。后来没办法,在程序结束时加上了GC.Collect()。

而且试验发现并不是每个AE对象都必须要释放,例如:

IWorkspaceFactory pFtWsFct = new AccessWorkspaceFactory();

IWorkspaceName workspaceName = pWorkspace = pFtWsFct.OpenFromFile(“F:\test.mdb”, 0);

IFeatureWorkspace featureWorkspace = (IFeatureWorkspace)pWorkspace;

.........

在对象运行结束时释放:

System.Runtime.InteropServices.Marshal.ReleaseComObject(pFtWsFct);

System.Runtime.InteropServices.Marshal.ReleaseComObject(workspaceName );

GC.Collect();

而GC.Collect()的解释是:强制对所有代进行即时垃圾回收。看了一篇文章:https://www.cnblogs.com/gisoracle/p/6843794.html

可能是与COM包装(COM Wrapper)有关吧。运行时提供了包装类,使托管和非托管客户端认为它们是在其各自的环境中调用对象。 每当托管客户端对某个 COM 对象调用方法时,运行时就会创建一个运行时可调用包装 (RCW)。 

猜你喜欢

转载自blog.csdn.net/qq_33459369/article/details/83515213