快速业务通道

关于freetds内存泄漏的问题

作者 佚名技术 来源 Linux系统 浏览 发布时间 2012-04-25

  在使用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 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号