Delphi 2009泛型容器单元(Generics.Collections)[3]: TStack<T>

TQueue 和 TStack, 一个是队列列表, 一个是堆栈列表; 一个是先进先出, 一个是先进后出.

TStack 主要有三个方法、一个属性:

Push(压栈)、Pop(出栈)、Peek(查看下一个要出栈的元素);

Count(元素总数).

本例效果图:

代码文件:unit Unit1;
interface
uses
 Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
 Dialogs, StdCtrls;
type
 TForm1 = class(TForm)
  Memo1: TMemo;
  Button1: TButton;
  Button2: TButton;
  Button3: TButton;
  procedure FormCreate(Sender: TObject);
  procedure FormDestroy(Sender: TObject);
  procedure Button1Click(Sender: TObject);
  procedure Button2Click(Sender: TObject);
  procedure Button3Click(Sender: TObject);
 end;
var
 Form1: TForm1;
implementation
{$R *.dfm}
uses Generics.Collections; {Delphi 2009 新增的泛型容器单元}
type
 TRec = record
  Name: string;
  Age: Word;
 end;
var
 Stack: TStack<TRec>; {定义一个泛型 TStack 类, 这指定了要用于上面定义的 TRec 记录}
{建立}
procedure TForm1.FormCreate(Sender: TObject);
begin
 Stack := TStack<TRec>.Create;
 Memo1.Clear;
 Button1.Caption := Button1.Caption + ' 压栈';
 Button2.Caption := Button2.Caption + ' 出栈';
 Button3.Caption := Button3.Caption + ' 下一个出栈的...';
end;
{释放}
procedure TForm1.FormDestroy(Sender: TObject);
begin
 Stack.Free;
end;
{压栈: Push}
procedure TForm1.Button1Click(Sender: TObject);
var
 rec: TRec;
begin
 rec.Name := StringOfChar(Char(65 + Random(26)), 3);
 rec.Age := Random(150);
 Stack.Push(rec);
 Text := Format('当前队列成员总数: %d', [Stack.Count]);
 {让 Memo1 配合显示}
 Memo1.Lines.Add(Format('%s, %d', [rec.Name, rec.Age]));
end;
{出栈: Pop}
procedure TForm1.Button2Click(Sender: TObject);
var
 rec: TRec;
begin
 if Stack.Count = 0 then Exit;
 rec := Stack.Pop;
 ShowMessage(Format('%s, %d', [rec.Name, rec.Age]));
 Text := Format('当前队列成员总数: %d', [Stack.Count]);
 {让 Memo1 配合显示}
 Memo1.Lines.Delete(Memo1.Lines.Count - 1);
end;
{下一个出列的的元素: Peek}
procedure TForm1.Button3Click(Sender: TObject);
var
 rec: TRec;
begin
 if Stack.Count = 0 then Exit;
 rec := Stack.Peek;
 ShowMessage(Format('%s, %d', [rec.Name, rec.Age]));
end;
end.

时间: 2024-09-20 20:46:11

Delphi 2009泛型容器单元(Generics.Collections)[3]: TStack&lt;T&gt;的相关文章

Delphi 2009泛型容器单元(Generics.Collections)[1]: TList

Delphi 2009 新增了泛型容器单元: Generics.Collections, 同时还有一个 Generics.Defaults 单元做支持. Generics.Collections 包含了以下实用类: TList<T> TQueue<T> TStack<T> TDictionary<TKey,TValue> TObjectList<T> TObjectQueue<T> TObjectStack<T> TObj

Delphi 2009泛型容器单元(Generics.Collections)[4]: TDictionary&amp;lt;T&amp;gt;

TDictionary 类似哈希表. 本例效果图: 代码文件:unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls; type TForm1 = class(TForm) Memo1: TMemo; Edit1: TEdit; Edit2: TEdit; Button1: TButton; Button2: TB

Delphi 2009泛型容器单元(Generics.Collections)[2]: TQueue&amp;lt;T&amp;gt;

TQueue 和 TStack, 一个是队列列表, 一个是堆栈列表; 一个是先进先出, 一个是先进后出. TQueue 主要有三个方法.一个属性: Enqueue(入列).Dequeue(出列).Peek(查看下一个要出列的元素); Count(元素总数). 本例效果图: 代码文件:unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialog

Delphi 2009泛型容器单元(Generics.Collections)[5]: TObject...&amp;lt;T&amp;gt; 系列

已经有了: TList<T>.TQueue<T>.TStack<T>.TDictionary<TKey,TValue> 为什么还有: TObjectList<T>.TObjectQueue<T>.TObjectStack<T>.TObjectDictionary<TKey,TValue> ? 还记得 Classes.TList 和 Contnrs.TObjectList 的主要区别吗? 如果元素是对象, Con

Delphi 2009的反射单元(ObjAuto)

ObjAuto 单元应该算是对 TypInfo 单元的功能扩展吧? 它提供了 5 个方法: GetMethods.GetMethodInfo.CreateMethodPointer.ReleaseMethodPointer.ObjectInvoke 通过 GetMethods.GetMethodInfo 可以获取类公用成员的详细信息. 通过 TypInfo 只能获取 published 区中成员的信息(例子); 通过 ObjAuto 也能获取 public 区的成员信息. 本例效果图: 本例有两

Delphi 2009之TStringBuilder类[5]: Chars[]属性与CopyTo方法

unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls; type TForm1 = class(TForm) Button1: TButton; Button2: TButton; procedure Button1Click(Sender: TObject); procedure Button2Click(Se

Delphi 2009之TStringBuilder类[4]: Insert与Remove

unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls; type TForm1 = class(TForm) Button1: TButton; procedure Button1Click(Sender: TObject); end; var Form1: TForm1; implementation {$R

Delphi 2009之TStringBuilder类[3]: Replace

unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls; type TForm1 = class(TForm) Button1: TButton; Button2: TButton; Button3: TButton; Button4: TButton; procedure Button1Click(Sender:

Delphi 2009之TStringBuilder类[2]: Append与AppendFormat

unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls; type TForm1 = class(TForm) Button1: TButton; Button2: TButton; Button3: TButton; Button4: TButton; Button5: TButton; procedure Bu