我是否符合人工QSqlDatabase限制?

时间:2016-02-17 23:59:01

标签: linux qt sqlite

我有一个功能已经很好地工作了很长时间,开始

QSqlDatabase
DBUtil :: basic_open (const QString & path)
{
    static int connection_num = 0;
    static const QString CONNECTION_NAME = "Connection%1";

    QSqlDatabase db = QSqlDatabase :: addDatabase (
        "QSQLITE",
        CONNECTION_NAME .arg (connection_num++));

    db .setDatabaseName (path);

    if (false == db .open ())
    {
         // error

我正在使用它打开并阅读许多小型SQLite数据库,每个数据库大约200k,当打开第1013个数据库时,它会失败

 out of memory Error opening database

应用程序的总内存负载大约为200M,机器上有可用的千兆字节。

看起来我正在达到除了纯粹的记忆之外的极限。在创建下一个QSqlDatabase对象之前,每个QSqlDatabase对象都会超出循环范围,这些数据库并非全部同时存在,并且我看不到文档中提到的任何连接限制。所以我很困惑。

lsof在此循环开始之前报告大约200个打开文件句柄,在它完成时报告大约1,200个,所以看起来Qt在~QSqlDatabase之后保持句柄打开,但是,如果这是限制,它似乎有点低

知道发生了什么事吗?这是最新的Ubuntu。

1 个答案:

答案 0 :(得分:1)

首先 - QSqlDatabase是一个单例,因此范围无关紧要。

在开启新作品之前尝试close connection