半砖 2022-02-16 16:06 采纳率: 0%
浏览 15

Sqlite3内存不断增加的问题

在嵌入式环境下集成 sqlite3 数据库,但是在插入数据时,发现内存不断增加的问题,调试到最后发现是执行 sqlite3_exec() 函数引起的,注释该函数就不会导致内存增加,请问这个要怎么处理呢?

代码如下:

int ExecDBSQL(sqlite3 *pSqliteDb, char *pSqlBuf)
{
    int ret = 0;
    char *pErrmsg = NULL;

    if ((NULL == pSqlBuf) || (strlen(pSqlBuf) < 5))
    {
        printf("pSqlBuf is null\n");
        return -1;
    }

    ret = sqlite3_exec(pSqliteDb, pSqlBuf, NULL, NULL, &pErrmsg);
    if (DB_OK != ret)
    {
        printf("sqlite3 exec error, ret: %d, errmsg: %s\n", ret, pErrmsg);
    }
    sqlite3_free(pErrmsg);

    return ret;
}

  • 写回答

1条回答 默认 最新

  • 赵4老师 2022-02-16 18:00
    关注

    你不断插入,内存就不断增加;
    同样
    你不断删除,内存就不断减少。
    (^_^)

    评论

报告相同问题?

问题事件

  • 修改了问题 2月16日
  • 创建了问题 2月16日

悬赏问题

  • ¥15 划分vlan后不通了
  • ¥15 GDI处理通道视频时总是带有白色锯齿
  • ¥20 用雷电模拟器安装百达屋apk一直闪退
  • ¥15 算能科技20240506咨询(拒绝大模型回答)
  • ¥15 自适应 AR 模型 参数估计Matlab程序
  • ¥100 角动量包络面如何用MATLAB绘制
  • ¥15 merge函数占用内存过大
  • ¥15 使用EMD去噪处理RML2016数据集时候的原理
  • ¥15 神经网络预测均方误差很小 但是图像上看着差别太大
  • ¥15 单片机无法进入HAL_TIM_PWM_PulseFinishedCallback回调函数