关于freetds内存泄漏的问题
在使用freetds时发现进行频繁的连接,关闭数据库时,出现内存持续增长.在网上搜索了一下,国内的文章就那几篇,和我使用的方法一样.在官方网站上找到了原因,写出来,供大家参考使用,下面的代码,是从网上找的,红色部分是需要增加的.该示例只执行一次,隐藏了内存泄漏的问题. Freetds的作者说dbinit,dbexit执行一次,再测试过程中执行多次也没事. #include <stdio.h> #include <string.h> #include <stdlib.h> #include <unistd.h> #include <sybfront.h> #include <sybdb.h> int main(void) { while(1) { char szUsername[32] = "test"; char szPassword[32] = "test"; char szDBName[32] = "test"; char szServer[32] = "2.2.2.2:1433"; //初始化db-library dbinit(); //连接数据库 LOGINREC *loginrec = dblogin(); DBSETLUSER(loginrec, szUsername); DBSETLPWD(loginrec, szPassword); DBPROCESS *dbprocess = dbopen(loginrec, szServer); if(dbprocess == FAIL){ printf("ASB>> Conect MS SQL SERVER fail n"); return 0; }else{ printf("ASB>> ConnectEMS conect MS SQL SERVER successn"); } if(dbuse(dbprocess, szDBName) == FAIL){ printf("ASB>> Open database name failn"); }else{ printf("ASB>> Open database name successn"); }
//查询数据库 dbcmd(dbprocess, "select ID,BeginTime,Description from Alarms"); if(dbsqlexec(dbprocess) == FAIL){ printf("ASB>> Query Alarms table errorn"); } DBINT result_code; char szID[1024]; char szBeginTime[1024]; char szDescription[1024]; int rows = 0; while ((result_code = dbresults(dbprocess)) != NO_MORE_RESULTS){ if (result_code == SUCCEED){ dbbind(dbprocess, 1, CHARBIND, (DBINT)0, (BYTE*)szID); dbbind(dbprocess, 2, CHARBIND, (DBCHAR)0, (BYTE*)szBeginTime); dbbind(dbprocess, 3, CHARBIND, (DBCHAR)0, (BYTE*)szDescription); while (dbnextrow(dbprocess) != NO_MORE_ROWS){ printf("ASB>> ID=%sn", szID); printf("ASB>> szAid=%sn", szBeginTime); printf("ASB>> szBeginTime=%sn", szDescription); } } } //关闭数据库连接 dbclose(dbprocess); dbloginfree(loginrec); dbexit(); usleep(1000); } return 0; } 可任意转载,但请保留出处,http://rainfish.cublog.cn/ |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |