基于Mysql C Api编写mysql客户端程序

本文介绍在单线程及多线程环境下如何正确连接和关闭MySQL数据库以避免内存泄漏的问题,提供了具体的示例代码,并强调了在多线程环境中进行资源管理和线程保护的重要性。

在编写mysql客户端程序时,最常见的就是连接mysql,和关闭mysql,在这里需要注意,如果使用不当将会造成内存泄漏。


单线程环境:一般使用 -lmysqlclient链接mysql客户库,mysql_init函数会自动调用my_library_init初始化mysql库,所以不需要,需要注意的是这两个函数都是非线程安全的。

示例代码如下:

/* mysql连接 */
void pa_mysql_connect(MYSQL *mysql_conn) {
	my_init();
	if (NULL == mysql_init(mysql_conn)) {
		write_log("Colud not init mysql.");
	}

	if (!mysql_real_connect(mysql_conn, g_mysql->host, g_mysql->username, g_mysql->passwd, g_mysql->dbname, g_mysql->port, NULL, 0)) {
		write_log("Mysql connect error : .", mysql_error(mysql_conn));
	}
}

/* 关闭mysql连接 */
void pa_mysql_close(MYSQL *mysql_conn) {
	mysql_close(mysql_conn);
	mysql_conn = NULL;
}

多线程环境:一般调用-lmysqlclient_r调用mysql安全类库,需要在各个线程中调用mysql_library_init、mysql_library_end来分配和释放mysql资源,或者增加线程锁保护资源,否则会造成内存泄漏。

示例代码如下:

/* mysql连接 */
void pa_mysql_connect(MYSQL *mysql_conn) {
	my_init();
	if (NULL == mysql_init(mysql_conn)) {
		write_log("Colud not init mysql.");
	}
	if (mysql_library_init(0, NULL, NULL)) {
		write_log("Could not initialize mysql library.");
	}
	if (!mysql_real_connect(mysql_conn, g_mysql->host, g_mysql->username, g_mysql->passwd, g_mysql->dbname, g_mysql->port, NULL, 0)) {
		write_log("Mysql connect error : .", mysql_error(mysql_conn));
	}
}


/* 关闭mysql连接 */
void pa_mysql_close(MYSQL *mysql_conn) {
	mysql_close(mysql_conn);
	mysql_conn = NULL;
	mysql_library_end();
}



参考资料:
http://www.souzz.net/online/MySQL/manual_Clients.html

http://dev.mysql.com/doc/refman/5.0/en/

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值