zoukankan      html  css  js  c++  java
  • 三、Delphi 2009 泛型容器单元(Generics.Collections)[2]: TQueue<T>

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

    TQueue 主要有三个方法、一个属性:
    Enqueue(入列)、Dequeue(出列)、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
      Queue: TQueue
    <TRec>;  {定义一个泛型 TQueue 类, 这指定了要用于上面定义的 TRec 记录}

    {建立}
    procedure TForm1.FormCreate(Sender: TObject);
    begin
      Queue :
    = TQueue<TRec>.Create;

      Memo1.Clear;
      Button1.Caption :
    = Button1.Caption + ' 入列';
      Button2.Caption :
    = Button2.Caption + ' 出列';
      Button3.Caption :
    = Button3.Caption + ' 下一个出列的';
    end;

    {释放}
    procedure TForm1.FormDestroy(Sender: TObject);
    begin
      Queue.Free;
    end;

    {入列: Enqueue}
    procedure TForm1.Button1Click(Sender: TObject);
    var
      rec: TRec;
    begin
      rec.Name :
    = StringOfChar(Char(65 + Random(26)), 3);
      rec.Age :
    = Random(150);
      Queue.Enqueue(rec);
      Text :
    = Format('当前队列成员总数: %d', [Queue.Count]);

      
    {让 Memo1 配合显示}
      Memo1.Lines.Add(Format(
    '%s, %d', [rec.Name, rec.Age]));
    end;

    {出列: Dequeue}
    procedure TForm1.Button2Click(Sender: TObject);
    var
      rec: TRec;
    begin
      
    if Queue.Count = 0 then Exit;
      rec :
    = Queue.Dequeue;
      ShowMessage(Format(
    '%s, %d', [rec.Name, rec.Age]));
      Text :
    = Format('当前队列成员总数: %d', [Queue.Count]);

      
    {让 Memo1 配合显示}
      Memo1.Lines.Delete(
    0);
    end;

    {下一个出列的元素: Peek}
    procedure TForm1.Button3Click(Sender: TObject);
    var
      rec: TRec;
    begin
      
    if Queue.Count = 0 then Exit;
      rec :
    = Queue.Peek;
      ShowMessage(Format(
    '%s, %d', [rec.Name, rec.Age]));
    end;

    end.
    DFM
  • 相关阅读:
    我的安卓开始
    OLAP的一些知识——接下去的项目需要的背景
    关于Java接口
    Hexo+Github/Coding免费搭建个人博客网站
    手机自带输入法emoji表情的输入,提交及显示——前端解决方案
    改变函数中的 this 指向——神奇的call,apply和bind及其应用
    什么是jsonp?——使用jsonp解决跨域请求问题
    玩转angularJs——通过自定义ng-model,不仅仅只是input可以实现双向数据绑定
    利用jquery mobiscroll插件选择日期、select、treeList的具体运用
    转载:中年程序猿的迷茫,你还在深究技术吗?
  • 原文地址:https://www.cnblogs.com/jxgxy/p/1595100.html
Copyright © 2011-2022 走看看