sqlite内存泄漏解决办法

前端之家收集整理的这篇文章主要介绍了sqlite内存泄漏解决办法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

sqlite内存泄漏解决办法

2012-09-26 13:54:54|分类 默认分类 |举报 |字号订阅

用cppsqlite发生内存泄漏,最后发现是把事物当普通语句去执行了。

其实本质是下面的:

1. 在使用

sqlite3_get_table(
sqlite3 *db,/* An open database */
const char *zsql,/* sql to be evaluated */
char ***pazResult,/* Results of the query */
int *pnRow,/* Number of result rows written here */
int *pnColumn,/* Number of result columns written here */
char **pzErrmsg /* Error msg written here */
);

后,要调用 sqlite3_free_table(pazResult) 来释放结果集,防止内存泄露


2. 在使用

sqlite3_exec(
sqlite3*,/* An open database */
const char *sql,/* sql to be evaluated */
int (*callback)(void*,int,char**,char**),/* Callback function */
void *,/* 1st argument to callback */
char **errmsg /* Error msg written here */
);

后,要调用 sqlite3_free(*errmsg) 来释放错误信息,防止内存泄露

猜你在找的Sqlite相关文章