Delphi中类似Map的HashTable

From: http://topic.csdn.net/t/20050518/10/4015559.html 

unit   UnitHasedTable;         interface     uses         Classes;         type         TStringHashedTable   =   class(TPersistent)             FKeyList:   TStrings;             FStrList:   TStrings;         private             function   GetItems(Key:   string):   string;             procedure   SetItems(Key:   string;   const   Value:   string);             function   GetCount:   Integer;         public             constructor   Create;             destructor   Destroy;   override;             property   Items[Key:   string]:   string   read   GetItems   write   SetItems;   default;             property   Count:   Integer   read   GetCount;             procedure   Add(Key,   Str:   string);             procedure   Delete(Key:String);             end;         implementation         {   TStringHashedTable   }         procedure   TStringHashedTable.Add(Key,   Str:   string);     begin         if   FKeyList.IndexOf(Key)   <>   -1   then         begin                 Exit;         end;         FKeyList.Add(Key);         FStrList.Add(Str);     end;         constructor   TStringHashedTable.Create;     begin             FKeyList   :=   TStringList.Create;         FStrList   :=   TStringList.Create;     end;         procedure   TStringHashedTable.Delete(Key:String);     var         KeyIndex:Integer;     begin         KeyIndex   :=   FKeyList.IndexOf(Key);         FKeyList.Delete(KeyIndex);         FStrList.Delete(KeyIndex);     end;         destructor   TStringHashedTable.Destroy;     begin         FStrList.Free;         FKeyList.Free;         inherited   Destroy;     end;         function   TStringHashedTable.GetCount:   Integer;     begin         Result   :=   FKeyList.Count;     end;         function   TStringHashedTable.GetItems(Key:   string):   string;     var         KeyIndex                                   :   Integer;     begin         KeyIndex     :=FKeyList.IndexOf(Key);         Result   :=   FStrList[KeyIndex];     end;         procedure   TStringHashedTable.SetItems(Key:   string;   const   Value:   string);     var         KeyIndex                                   :   Integer;     begin         KeyIndex     :=FKeyList.IndexOf(Key);         FStrList[KeyIndex]   :=   Value;     end;         end.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值