程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> Delphi >> Delphi中的容器類(9)

Delphi中的容器類(9)

編輯:Delphi

THashedStringList類

一般來說,通過鍵來查找值最簡單的辦法是遍歷列表對列表中的鍵進行比較,如果相等則獲取相應的鍵值。但是這種簡單的辦法也是效率最差的一種辦法,當列表中的項目比較少時,這種辦法還可以接受,但是如果列表中項目非常多的話,這種方法會極大的影響軟件的運行速度。 這時我們可以使用哈希表來快速的通過鍵值來存取列表中的元素。由於本書並不是一本數據結構和算法的書,因此我無意在這裡討論哈希表背後的理論知識,我們只要知道哈希可以通過鍵快速定位相應的值就可以了,對此感興趣的非計算機專業的人可以去察看相關的書,這裡就不贅述了。

Delphi6中提供的THashedStringList類沒有提供任何的新的方法,只是對IndexOf和IndexOfName函數通過哈希表進行了性能優化,下面這個例子演示了TStringList和THashedStringList之間的性能差異:

unit CHash;
interface
uses
 Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
 Dialogs, StdCtrls, Inifiles;
type
 TForm1 = class(TForm)
  Button1: TButton;
  procedure Button1Click(Sender: TObject);
  procedure FormCreate(Sender: TObject);
  procedure FormDestroy(Sender: TObject);
 private
  { Private declarations }
  HashedList: THashedStringList;
  DesList: TStringList;
  List: TStringList;
 public
  { Public declarations }
  procedure Hash;
  procedure Iterate;
 end;
var
 Form1: TForm1;
implementation
{$R *.dfm}
procedure TForm1.Button1Click(Sender: TObject);
var
 I:Integer;
begin
 Screen.Cursor := crHourGlass;
 try
//初始化系統
  for I := 0 to 5000 do
  begin
   HashedList.Add(IntToStr(i));
   List.Add(IntToStr(i));
  end;
  Hash;
  DesList.Clear;
  Iterate;
 finally
  Screen.Cursor := crDefault;
 end;
end;
procedure TForm1.Hash;
var
 I, J: Integer;
begin
 //基於哈希表的定位
 for I := 3000 to 4000 do
 begin
  DesList.Add(IntToStr(HashedList.IndexOf(IntToStr(I))));
 end;
end;
procedure TForm1.Iterate;
var
 I, J: Integer;
begin
 //基於遍歷方式定位
 for I := 3000 to 4000 do
 begin
  DesList.Add(IntToStr(List.IndexOf(IntToStr(I))));
 end;
end;
procedure TForm1.FormCreate(Sender: TObject);
begin
 HashedList := THashedStringList.Create;
 DesList := TStringList.Create;
 List := TStringList.Create;
end;
procedure TForm1.FormDestroy(Sender: TObject);
begin
 HashedList.Free;
 DesList.Free;
 List.Free;
end;
end.

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved