c mysql close,c-连接失败时需要mysql_close吗?

我有一个代码片段,可以像这样连接到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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值