我有一个代码片段,可以像这样连接到MySQL数据库(不是直接从代码中读取,因此可能会有错别字):
m_connectionHandler = mysql_init(NULL);
if (m_connectionHandler == NULL)
{
// MySQL initialization failed
return;
}
MYSQL *tmp = mysql_real_connect(m_connectionHandler,
m_hostname,
m_username,
m_password,
m_dbName,
m_port,
NULL,
m_flags);
if (tmp == NULL)
{
// Connect failed
mysql_close(m_connectionHandler);
return;
}
我的问题是,在mysql_real_connect返回NULL的情况下,是否需要mysql_close(在第二条if子句tmp == NULL中),或者在失败时mysql_real_connect是否为我释放连接处理程序?
该文档确实指出,从mysql_init获得的内容应该由mysql_close释放,但是有迹象表明,一旦失败,它就已经由mysql_real_connect释放了.
谁能为我阐明一下?
解决方法:
您对mysql_init(NULL)的调用分配了内存.无论您是否能够真正连接到服务器,都仍然分配了内存,因此需要使用mysql_close释放它,它不仅关闭连接而且释放内存.我在文档中没有看到mysql_real_connect会释放内存本身的指示.
标签:mysql,c-4
来源: https://codeday.me/bug/20191107/2002912.html