zoukankan      html  css  js  c++  java
  • 泛型容器单元(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.

    窗体文件:


    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
  • 相关阅读:
    Elasticsearch常用插件集合(转)
    istio 安装与bookinfo示例运行(转)
    kubernetes发布tomcat服务,通过deployment,service布署(转)
    记一次ceph集群的严重故障 (转)
    Linux centos 7 安装NFS服务
    Centos7下使用Ceph-deploy快速部署Ceph分布式存储-操作记录(转)
    docker 安装 jmeter
    idea 2018.1破解激活方法,有效期至2099年
    MySQL和Oracle的区别
    SpringCloud面试题
  • 原文地址:https://www.cnblogs.com/rogge7/p/4603872.html
Copyright © 2011-2022 走看看