mysql,mysql mysql_real_connect 內存泄露

 2023-10-07 阅读 28 评论 0

摘要:轉自:http://blog.csdn.net/weihua1984/archive/2010/08/24/5835731.aspx linux 下使用c操作mysql數據庫時寫個測試程序 view plaincopy to clipboardprint? int?main(void)??{??????MYSQL?m_mysql;??????mysql_init(&m_mysql);????????????const?char?pLocalhost[

轉自:http://blog.csdn.net/weihua1984/archive/2010/08/24/5835731.aspx

linux 下使用c操作mysql數據庫時寫個測試程序

view plaincopy to clipboardprint?
  1. int?main(void)??
  2. {??
  3. ????MYSQL?m_mysql;??
  4. ????mysql_init(&m_mysql);??
  5. ??????
  6. ????const?char?pLocalhost[]?=?"localhost";??
  7. ????const?char?pUser[]?=?"root";??
  8. ????const?char?pPass[]?=?"123456";??
  9. ????const?char?pDB[]?=?"HTTPCONTROL";??
  10. ??????
  11. ????if(mysql_real_connect(&m_mysql,pLocalhost,pUser,pPass,pDB,0,NULL,0)?==?NULL)??
  12. ????????cout<<"connect?failed"<<endl;??
  13. ????else??
  14. ????????cout<<"connect?success"<<endl;??
  15. ???????
  16. ????mysql_close(&m_mysql);??????
  17. ????return?0;??
  18. }??

編譯后使用valgrind檢測內存泄露

[root@localhost string]# valgrind --tool=memcheck --leak-check=full ./mysql?
==10352== Memcheck, a memory error detector
==10352== Copyright (C) 2002-2009, and GNU GPL'd, by Julian Seward et al.
==10352== Using Valgrind-3.5.0 and LibVEX; rerun with -h for copyright info
==10352== Command: ./mysql
==10352==?
connect success
==10352==?
==10352== HEAP SUMMARY:
==10352==???? in use at exit: 61,336 bytes in 16 blocks
==10352==?? total heap usage: 118 allocs, 102 frees, 115,929 bytes allocated
==10352==?
==10352== 24,528 bytes in 6 blocks are possibly lost in loss record 4 of 5
==10352==??? at 0x4005903: malloc (vg_replace_malloc.c:195)
==10352==??? by 0x30DD75: my_once_alloc (in /usr/lib/mysql/libmysqlclient.so.15.0.0)
==10352==??? by 0x30E59C: ??? (in /usr/lib/mysql/libmysqlclient.so.15.0.0)
==10352==??? by 0x30EF96: ??? (in /usr/lib/mysql/libmysqlclient.so.15.0.0)
==10352==??? by 0x30F111: get_charset_by_csname (in /usr/lib/mysql/libmysqlclient.so.15.0.0)
==10352==??? by 0x32C3D2: mysql_init_character_set (in /usr/lib/mysql/libmysqlclient.so.15.0.0)
==10352==??? by 0x32DABB: mysql_real_connect (in /usr/lib/mysql/libmysqlclient.so.15.0.0)
==10352==??? by 0x8048A76: main (str.cpp:32)
==10352==?
==10352== 28,616 bytes in 7 blocks are possibly lost in loss record 5 of 5
==10352==??? at 0x4005903: malloc (vg_replace_malloc.c:195)
==10352==??? by 0x30DD75: my_once_alloc (in /usr/lib/mysql/libmysqlclient.so.15.0.0)
==10352==??? by 0x30E57A: ??? (in /usr/lib/mysql/libmysqlclient.so.15.0.0)
==10352==??? by 0x30EF96: ??? (in /usr/lib/mysql/libmysqlclient.so.15.0.0)
==10352==??? by 0x30F111: get_charset_by_csname (in /usr/lib/mysql/libmysqlclient.so.15.0.0)
==10352==??? by 0x32C3D2: mysql_init_character_set (in /usr/lib/mysql/libmysqlclient.so.15.0.0)
==10352==??? by 0x32DABB: mysql_real_connect (in /usr/lib/mysql/libmysqlclient.so.15.0.0)
==10352==??? by 0x8048A76: main (str.cpp:32)
==10352==?
==10352== LEAK SUMMARY:
==10352==??? definitely lost: 0 bytes in 0 blocks
==10352==??? indirectly lost: 0 bytes in 0 blocks
==10352==????? possibly lost: 53,144 bytes in 13 blocks
==10352==??? still reachable: 8,192 bytes in 3 blocks
==10352==???????? suppressed: 0 bytes in 0 blocks
==10352== Reachable blocks (those to which a pointer was found) are not shown.
==10352== To see them, rerun with: --leak-check=full --show-reachable=yes
==10352==?
==10352== For counts of detected and suppressed errors, rerun with: -v
==10352== ERROR SUMMARY: 2 errors from 2 contexts (suppressed: 3

mysql、還是網上找最后找到了

http://dev.mysql.com/doc/refman/5.0/en/mysql-library-end.html

簡單的說是在斷開數據庫連接后使用

mysql_library_end()

關閉MYSQL 使用的庫

MySQL server,即在mysql_close(。。。)

后添加

mysql_library_end();

就ok了

再添加一句,在使用mysql API之前最好是

Java 內存泄漏。調用mysql_library_init(。。。。)

轉載于:https://www.cnblogs.com/talking/archive/2011/04/14/2015887.html

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/4/124492.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息