在GDB中插入数据后记得释放相关Com组件,否则表会一直被锁着。(IFeatureBuffer,IFeatureCursor,IFeatureClass)
今天在用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)。