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

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


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

示例代码如下:

  1. /* mysql连接 */  
  2. void pa_mysql_connect(MYSQL *mysql_conn) {  
  3.     my_init();  
  4.     if (NULL == mysql_init(mysql_conn)) {  
  5.         write_log("Colud not init mysql.");  
  6.     }  
  7.   
  8.     if (!mysql_real_connect(mysql_conn, g_mysql->host, g_mysql->username, g_mysql->passwd, g_mysql->dbname, g_mysql->port, NULL, 0)) {  
  9.         write_log("Mysql connect error : .", mysql_error(mysql_conn));  
  10.     }  
  11. }  
  12.   
  13. /* 关闭mysql连接 */  
  14. void pa_mysql_close(MYSQL *mysql_conn) {  
  15.     mysql_close(mysql_conn);  
  16.     mysql_conn = NULL;  
  17. }  

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

示例代码如下:

  1. /* mysql连接 */  
  2. void pa_mysql_connect(MYSQL *mysql_conn) {  
  3.     my_init();  
  4.     if (NULL == mysql_init(mysql_conn)) {  
  5.         write_log("Colud not init mysql.");  
  6.     }  
  7.     if (mysql_library_init(0, NULL, NULL)) {  
  8.         write_log("Could not initialize mysql library.");  
  9.     }  
  10.     if (!mysql_real_connect(mysql_conn, g_mysql->host, g_mysql->username, g_mysql->passwd, g_mysql->dbname, g_mysql->port, NULL, 0)) {  
  11.         write_log("Mysql connect error : .", mysql_error(mysql_conn));  
  12.     }  
  13. }  
  14.   
  15.   
  16. /* 关闭mysql连接 */  
  17. void pa_mysql_close(MYSQL *mysql_conn) {  
  18.     mysql_close(mysql_conn);  
  19.     mysql_conn = NULL;  
  20.     mysql_library_end();  
  21. }  



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

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


FROM:  http://blog.csdn.net/rainkid/article/details/7549490

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值