当前位置:首页>>开发编程>>综合开发>>新闻内容  
Delphi中Hash表的使用方法
作者: 发布时间:2007-2-5 15:27:38 | 【字体:
    在游戏开发中经常需要保存一些数据结构,并且在使用的时候需要快速的查找出来.Hash表正是为了提高检索速度而设计出来的.下面我就将我在用Delphi开发中使用Hash表的方法写出来,希望对大家有一定的帮助!

  在Delphi中有一个THashedStringlist类,使用这个类可以实现Hash表的操作.使用这个类需要引用IniFiles头文件.

  例如:我们定义的数据结构是:

以下是引用片段:
  RTest = record
  Key:Integer;
  Name:String[20];
  Sex:Boolean;
  Age:Integer;
  end;
  PTest = ^RTest ;
  1:创建Hash表.
  ScHash:=THashedStringlist.Create;
  2:将数据结构加入Hash表中.
  var
  Index:Integer;
  p_Test:PTest;
  Index:=ScHash.IndexOf(IntToStr(p_Test.Key));
  if Index=-1 then
  begin
  ScHash.AddObject(IntToStr(p_Test.Key),TObject(Integer(p_Test)));
  end;

  在加入Hash表的时候,首先我们检查看这个Key是否在Hash表中,如果Index=-1则说明此Key不在Hash表中,则我们将这个结构指针加入到Hash表中.

  3:将数据结构从Hash表中删除.

以下是引用片段:
  var
  Index:Integer;
  t_Object: TObject;
  Index:=ScHash.IndexOf(IntToStr(p_Test.Key));
  if Index<>-1 then
  begin
  t_Object:=ScHash.Objects[Index];
  ScHash.Delete(Index);
  end;

  4:删除Hash表

  在删除Hash表的时候和一般的Tlist删除一样,使用Free.

  ScHash.Free;


文章来源:
·CodeGear Rad Studio 2009 (Delphi 2009和C++Builder 2009) 开发工具下载
·Delphi2009/C++Builder2009有下载了!
·Borland以2300万美元出售Delphi(CodeGear)
·利用Delphi控制Windows任务栏
·用Delphi来编写蠕虫病毒浅析
·Delphi常用控件命名缩写规范
·Delphi中建议使用的语句
·用Delphi实现图像放大镜
·Delphi编程禁止用户关闭操作系统
 放生
 愚爱
 够爱
 触电
 白狐
 葬爱
 光荣
 画心
 火花
 稻香
 小酒窝
 下雨天
 右手边
 安静了
 魔杰座
 你不像她
 边做边爱
 擦肩而过
 我的答铃
 怀念过去
 等一分钟
 放手去爱
 冰河时代
 你的承诺
 自由飞翔
 原谅我一次
 吻的太逼真
 左眼皮跳跳
 做你的爱人
 一定要爱你
 飞向别人的床
 爱上别人的人
 感动天感动地
 心在跳情在烧
 玫瑰花的葬礼
 有没有人告诉你
 即使知道要见面
 爱上你是一个错
 最后一次的温柔
 爱上你是我的错
 怎么会狠心伤害我
 不是因为寂寞才想
 亲爱的那不是爱情
 难道爱一个人有错
 寂寞的时候说爱我