我已经尝试了日日夜夜的谷歌搜索和阅读 MySQL 文档,但我似乎无法找出可能导致内存泄漏的原因。
它似乎是随机发生的,这是唯一泄漏的功能。
代码:
unsigned long numRowQuery(std::string query)
{
MYSQL *connection = mysql_init(NULL);
MYSQL_RES *result;
unsigned long num_rows;
// connecting to database
if(!mysql_real_connect(connection,SERVER,USER,PASSWORD,DATABASE,0,NULL,0))
{
std::cout << "Connection error: " << mysql_error(connection) << std::endl;
}
if (mysql_query(connection, query.c_str()))
{
std::cout << "MySQL query error: " << mysql_error(connection) << std::endl;
exit(1);
}
result = mysql_store_result(connection);
num_rows = mysql_num_rows(result);
mysql_free_result(result);
mysql_close(connection);
mysql_library_end();
return num_rows;
}