在编写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/