Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1272745
  • 博文数量: 788
  • 博客积分: 4000
  • 博客等级: 上校
  • 技术积分: 7005
  • 用 户 组: 普通用户
  • 注册时间: 2008-08-19 15:52
文章存档

2017年(81)

2011年(1)

2009年(369)

2008年(337)

分类:

2008-10-14 16:38:58



类方法:  
  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;     //   这样就干净了。。

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



[新闻]Silverlight对Flash 微软打垮Adobe
博客园首页 社区 新闻频道 小组 博问 网摘 闪存
阅读(760) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~