首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我是否达到了人为的QSqlDatabase限制?

我是否达到了人为的QSqlDatabase限制?
EN

Stack Overflow用户
提问于 2016-02-18 07:59:01
回答 1查看 117关注 0票数 2

我有一个多年来一直运行良好的函数,它开始于

代码语言:javascript
复制
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个数据库时,会出现以下错误

代码语言:javascript
复制
 out of memory Error opening database

应用程序的总内存负载约为200M,机器上有‘s的空闲空间。

看起来我达到了一个极限,而不是纯粹的记忆。在创建下一个对象之前,每个QSqlDatabase对象都超出了循环作用域,这些数据库并不都是并发存在的,并且我看不到文档中提到的任何连接限制。所以我很困惑。

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

知道是怎么回事吗?这是在最新的Ubuntu上。

EN

回答 1

Stack Overflow用户

发布于 2016-02-18 10:05:01

首先-- QSqlDatabase是一个单例,所以作用域并不重要。

在打开新文件之前尝试close connection

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35470198

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档