- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我在尝试删除文件之前关闭数据库时遇到问题。代码只是
myconnection.Close();
File.Delete(filename);
并且 Delete 抛出一个文件仍在使用中的异常。几分钟后,我在调试器中重新尝试了 Delete(),所以这不是时间问题。
我有事务代码,但它在 Close() 调用之前根本不运行。所以我相当确定这不是公开交易。 open和close之间的sql命令只是select。
ProcMon 显示我的程序和我的防病毒软件查看数据库文件。它没有显示我的程序在 close() 之后释放 db 文件。
Visual Studio 2010、C#、System.Data.SQLite 版本 1.0.77.0、Win7
我看到了一个两年前的错误,就像这样,但变更日志说它已修复。
还有什么我可以检查的吗?有没有办法获取任何打开的命令或事务的列表?
新的工作代码:
db.Close();
GC.Collect(); // yes, really release the db
bool worked = false;
int tries = 1;
while ((tries < 4) && (!worked))
{
try
{
Thread.Sleep(tries * 100);
File.Delete(filename);
worked = true;
}
catch (IOException e) // delete only throws this on locking
{
tries++;
}
}
if (!worked)
throw new IOException("Unable to close file" + filename);
最佳答案
不久前在为 C# 编写 DB 抽象层时遇到了同样的问题,但我从来没有真正抽出时间找出问题所在。当您尝试使用我的库删除 SQLite 数据库时,我刚刚抛出异常。
无论如何,今天下午我再次仔细查看了所有内容,并想我会一劳永逸地找出它这样做的原因,所以这是我到目前为止所发现的。
当您调用 SQLiteConnection.Close()
时会发生什么(连同许多检查和其他事情)指向 SQLite 数据库实例的 SQLiteConnectionHandle
是处置。这是通过调用 SQLiteConnectionHandle.Dispose()
完成的,但是在 CLR 的垃圾收集器执行一些垃圾收集之前,这实际上并没有释放指针。由于 SQLiteConnectionHandle
覆盖了 CriticalHandle.ReleaseHandle()
函数来调用 sqlite3_close_interop()
(通过另一个函数),这不会关闭数据库。
在我看来,这是一种非常糟糕的做事方式,因为程序员实际上并不确定数据库何时关闭,但这就是它已经完成的方式,所以我想我们现在必须接受它,或对 System.Data.SQLite 进行一些更改。欢迎任何志愿者这样做,不幸的是我明年之前没有时间这样做。
长话短说解决方案是在调用 SQLiteConnection.Close()
之后和调用 File.Delete()
之前强制执行 GC。
示例代码如下:
string filename = "testFile.db";
SQLiteConnection connection = new SQLiteConnection("Data Source=" + filename + ";Version=3;");
connection.Close();
GC.Collect();
GC.WaitForPendingFinalizers();
File.Delete(filename);
祝你好运,希望对你有帮助
关于sqlite - System.Data.SQLite Close() 不释放数据库文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8511901/
我有一个附加了 View Controller 的 AVAudioPlayer 实例。 @property (nonatomic, retain) AVAudioPlayer *previewAudi
我是java初学者。假设我声明了一个 Account 类型的变量 Account _account = new Account("Thomas"); 然后在其他地方我做了这样的事情: _account
我在我的应用程序中使用了 3 个 UIViewController,现在我想知道当我从另一个应用程序切换到另一个 UIViewController 时释放它们是否是一个好主意。显然,这将是隐藏的,当它
我分配了一个直接缓冲区: ByteBuffer directBuffer = ByteBuffer.allocateDirect(1024); 我读过: Deallocating Direct Buf
场景。我有一个图表,我可以使用右键单击来执行平移。这非常有效。然后我完美地添加了右键菜单。 问题。现在,即使在拖动操作完成后释放鼠标,也会显示右键菜单。 有没有办法在 Java Swing 或 Jav
我使用此代码获取 ABPerson 的姓氏 CFStringRef lastNameRef = ABRecordCopyValue((ABRecordRef)personRecordRef, kABP
目前,我们在基于 C 的嵌入式应用程序中使用 malloc/free Linux 命令进行内存分配/取消分配。我听说这会导致内存碎片,因为内存分配/取消分配会导致堆大小增加/减少,从而导致性能下降。其
当我尝试释放缓冲区时遇到问题。每次我尝试将缓冲区传递给释放方法时,都会发生段错误。 Valgrind 确认段错误位于 BufferDeallocate 方法中。 ==30960== Memcheck,
我想知道何时按下或释放修改后的键(Ctrl 或 Shift)。 基本上,用户可以在按下修改键的情况下执行多次击键,而我不想在它被释放之前执行一个操作(想想 Emacs 和 Ctrl + X + S).
我编写了一个相当大的网络应用程序。它运行良好一段时间,然后慢慢开始运行缓慢,因为 DOM 节点开始爬升到 80,000 - 100,000 左右。 所以我一直在 Chrome 开发工具控制台 (DCT
我知道在像 c 这样的语言中,我需要在分配内存后释放它。 (我来自 Java),对此我有几个问题: 当我在做的时候: int array[30]; (即创建一个大小为 30 个整数的数组)与
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: How to release pointer from boost::shared_ptr? Detach
我有一个可以从多个后台线程访问的类,可能同时访问。我无法复制该类,因为重新创建它的内容(处理或内存方面)可能很昂贵。 也有可能在后台处理仍在继续并访问该属性时替换了此类的属性。 目前我有定期的保留/释
这个问题是对: 的扩展链接-1:Creating an image out of the ios surface and saving it Link-2:Taking Screenshots fro
我有一个实例变量 NSMutableArray* searchResults。 首先,我初始化它: self.searchResults = [[NSMutableArray alloc] init]
如果我在堆上声明一些东西,比如 char *a=new char[1000] 并且主程序停止,如果没有 delete[]<,那么分配的内存会发生什么 调用?它保留在堆上还是自动释放? 最佳答案 就C+
在开发相机应用时,我遇到了一个异常,该异常仅在我切换到其他应用时发生(onPause() 用于我的应用)。 01-15 17:22:15.017: E/AndroidRuntime(14336): F
使用 JDK 1.8 编译时出现 maven 编译器错误 无法执行目标 org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (de
将 BufferedImage 保存到磁盘(以释放内存)的最快方法是什么? 我的 Java 应用程序处理大量图像(每约 300 毫秒将图像加载到内存中)。大多数这些图像都会立即被丢弃 (gc),但每隔
使用 JDK 1.8 编译时出现 maven 编译器错误 未能在项目 DUMMY 上执行目标 org.apache.maven.plugins:maven-compiler-plugin:3.8.1:
我是一名优秀的程序员,十分优秀!