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

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

TStack 主要有三个方法、一个属性:
Push(压栈)、Pop(出栈)、Peek(查看下一个要出栈的元素);
Count(元素总数).

本例效果图:

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

代码文件:

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.


 
   
窗体文件:

object Form1: TForm1

  Left = 0

  Top = 0

  Caption = 'Form1'

  ClientHeight = 147

  ClientWidth = 284

  Color = clBtnFace

  Font.Charset = DEFAULT_CHARSET

  Font.Color = clWindowText

  Font.Height = -11

  Font.Name = 'Tahoma'

  Font.Style = []

  OldCreateOrder = False

  Position = poDesktopCenter

  OnCreate = FormCreate

  OnDestroy = FormDestroy

  PixelsPerInch = 96

  TextHeight = 13

  object Memo1: TMemo

    Left = 0

    Top = 0

    Width = 121

    Height = 147

    Align = alLeft

    Font.Charset = DEFAULT_CHARSET

    Font.Color = clWindowText

    Font.Height = -13

    Font.Name = 'Courier New'

    Font.Style = []

    Lines.Strings = (

      'Memo1')

    ParentFont = False

    ScrollBars = ssBoth

    TabOrder = 0

  end

  object Button1: TButton

    Left = 127

    Top = 21

    Width = 146

    Height = 25

    Caption = 'Button1'

    TabOrder = 1

    OnClick = Button1Click

  end

  object Button2: TButton

    Left = 127

    Top = 61

    Width = 146

    Height = 25

    Caption = 'Button2'

    TabOrder = 2

    OnClick = Button2Click

  end

  object Button3: TButton

    Left = 127

    Top = 99

    Width = 146

    Height = 25

    Caption = 'Button3'

    TabOrder = 3

    OnClick = Button3Click

  end

end


 
   

你可能感兴趣的:(Collections)