Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
memtrace
SQLite
内存泄漏leak
10
sqlite软件包内存泄漏
发布于 2022-05-22 11:06:39 浏览:1386
订阅该版
在4.1.0版本下使用sqlite软件包,从https://github.com/RT-Thread-packages/SQLite下载的源码并替换pkgs --update的sqlite文件(不知道为什么直接update的一运行就报`(obj != object) assertion failed at function:rt_object_init, line number:358`, 而从github下载的就能运行), 运行一段时间后发现使用内存不断增大,用memtrace工具确定是操作数据库的线程导致,请问造成内存泄漏到底是我应用程序的问题还是软件包本身的问题,该怎么排查呢?硬件使用的nuc980dk61yc ![aa.jpg](https://oss-club.rt-thread.org/uploads/20220522/bd2cbbf6495d69f6457ee594db0d716a.jpg) ```c void app_sqlite3_thread(void *argument) { sqlite3_initialize(); sqlite3 *db; char *zErrMsg = 0; int res; int start = 0; int index = 0; char cmd[128] = {0}; time_t now; rt_thread_mdelay(2000); res = sqlite3_open("/mnt/sd1/test.db", &db); if (res != 0) { LOG_E("open db fail"); rt_thread_mdelay(1000); return; } res = sqlite3_exec(db, "create table if not exists mydb(time vchar(30),fs1_1 float,fs1_2 float,fs2_1 float,fs2_2 float,fs3_1 float,fs3_2 float,temp1 char,temp2 char,temp3 char,current1 char,current2 char,current3 char,freq1 char,freq2 char,freq3 char)", 0, 0, &zErrMsg); if (res != 0) { LOG_E("create table fail"); sqlite3_free(zErrMsg); rt_thread_mdelay(1000); return; } res = sqlite3_exec(db, "PRAGMA synchronous=FULL", 0, 0, &zErrMsg); if (res != 0) { printf("set pragma fail\r\n"); sqlite3_free(zErrMsg); } while (1) { // printf("start: %d\r\n", rt_tick_get()); start = rt_tick_get(); rt_memset(cmd, 0, sizeof(cmd)); now = time(RT_NULL); rt_sprintf(cmd, "insert into mydb values('%s',1.2,2.6,3.1,4.7,0.9,4.2,10,25,28,12,36,28,30,19,24)", ctime(&now)); res = sqlite3_exec(db, cmd, 0, 0, &zErrMsg); if (res != 0) { LOG_E("insert data fail"); sqlite3_free(zErrMsg); } if (rt_tick_get() - start > 100) { // LOG_W("write time too long: %d",rt_tick_get() - start); } rt_thread_mdelay(20); } sqlite3_close(db); } int app_sqlite(void) { rt_thread_t tid = 0; tid = rt_thread_create("app_sqlite", app_sqlite3_thread, RT_NULL, 500 * 1024, 10, 300); if (tid != RT_NULL) { rt_thread_startup(tid); } else rt_kprintf("create sqlite app fail\r\n"); } INIT_APP_EXPORT(app_sqlite); ```
查看更多
lchnu
2022-05-23
Witness, Understand, Skill
对着代码仔细核对了最可疑的sqlite3_exec函数中关于最后一个二级指针的形参、内部处理代码,从这部分代码看不出什么问题。 错误msg的指向的内存,在返回值不为0的时候才在sqlite3_exec函数内部malloc,然后lz的代码也进行了free。 比较感兴趣,关注一下,看看lz后续的调试结果。 要不试着屏蔽一下sqlite3_exec,看看是否依然发生内存泄漏,别被memtrace的指向带偏了方向。
2
个回答
默认排序
按发布时间排序
张世争
2022-05-23
学以致用
是申请了没有正确释放还是软件包本身有问题?
撰写答案
登录
注册新账号
关注者
0
被浏览
1.4k
关于作者
老鸟kkk
这家伙很懒,什么也没写!
提问
10
回答
4
被采纳
1
关注TA
发私信
相关问题
1
Rtt如何使用sqlite?
2
关于sqlite的问题
3
招募测试人员,尝鲜最新版SQLite3 .19.3
4
哪位坛友能提供个SQLite3.81的原始版本么?
5
rt-thread组建sqlite3加入工程编译通不过
6
sqlite3数据库操作问题
7
RTT3.0 sqlite3编译报错问题
8
关于sqlite3编译报错问题
9
在stm32f4中添加SQLite packages,不能创建数据库
10
正点原子stm32f429阿波罗开发板上运行sqlite无法建表
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
RT-Thread中的time溢出问题,时间戳溢出,解决方法
2
ART-PI使用env驱动ETH网卡,pc和板子可以ping通
3
SystemView线程名字不显示
4
只用网页也能跑RT-Smart 无门槛腾讯Cloud studio + smart-build快速构建
5
免费申请 | FRDM-MCXA156评测活动发布!
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
I2C_IIC
ESP8266
UART
cubemx
WIZnet_W5500
ota在线升级
PWM
BSP
flash
freemodbus
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
keil_MDK
ulog
SFUD
msh
C++_cpp
MicroPython
本月问答贡献
RTT_逍遥
8
个答案
2
次被采纳
三世执戟
7
个答案
1
次被采纳
KunYi
6
个答案
1
次被采纳
winfeng
2
个答案
1
次被采纳
chenyaxing
2
个答案
1
次被采纳
本月文章贡献
catcatbing
2
篇文章
5
次点赞
swet123
1
篇文章
3
次点赞
YZRD
1
篇文章
2
次点赞
Days
1
篇文章
2
次点赞
阳光的掌控者
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部