看看这段代码有没有内存泄露?

讨论了在Delphi中使用TAdoQuery类返回数据集对象时的内存管理问题,指出若不正确释放资源,将导致内存泄漏,并提供了解决方案。
看看这段代码有没有内存泄露? Delphi / Windows SDK/API
http://www.delphi2007.net/DelphiBase/html/delphi_20061219185953114.html
类方法:  
  function   TAdoHelper.GetDataSet(sqlstr:   string;   params:   TStrings):   TDataSet;  
  var  
      TempQuery:   TAdoQuery;  
  begin  
      TempQuery:=   TAdoQuery.Create(nil);  
      TempQuery.Connection:=   FConnector;  
      TempQuery.Close;  
      TempQuery.SQL.Clear;  
      TempQuery.SQL.Add(sqlstr);  
      TempQuery.Prepared;  
      FillParameters(TempQuery,Params);  
      TempQuery.Open;  
      result:=   TempQuery;  
  end;  
   
  客户端:  
  result:=   MySqlHelper.GetDataSet(SQL_GetUserDataSet);  
   
  这样返回临时对象的引用,函数内部的临时对象tempquery何时释放?如果不释放会不会造成内存泄露?  
   
 

关注!

如果客户端的result没有free的话,会产生内存泄漏,即分配给tempquery的内存块没有了引用。  
  对于class类型的返回值,建议改成过程,使用变参传入。

function   TAdoHelper.GetDataSet(sqlstr:   string;   params:   TStrings):   TDataSet;  
  begin  
      Result   :=   TAdoQuery.Create(nil);  
      with   Result   do  
      begin  
          Connection:=   FConnector;  
          Close;  
          SQL.Clear;  
          SQL.Add(sqlstr);  
          Prepared;  
            FillParameters(Result,Params);  
          Open;  
      end;  
  end;  
   
  客户端:  
  AdataSet   :=     MySqlHelper.GetDataSet(SQL_GetUserDataSet);  
  ....  
  ADataSet.Free;     //   这样就干净了。。

恩,楼上说的是对的。这样做,应该是可以的。。

转载于:https://www.cnblogs.com/delphi2007/archive/2008/10/14/1310927.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值