zoukankan      html  css  js  c++  java
  • 二十三、详测 Generics Collections TQueue (3): OnNotify、Extract

    unit Unit1;

    interface

    uses
      Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
      Dialogs, StdCtrls, Generics.Collections;

    type
      TForm1 
    = class(TForm)
        Button1: TButton;
        
    procedure Button1Click(Sender: TObject);
      
    private
        
    procedure MyQueueNotify(Sender: TObject; const Item: Integer;
          Action: TCollectionNotification);
      
    end;

    var
      Form1: TForm1;

    implementation

    {$R *.dfm}

    //uses Generics.Collections;

    {准备给 TQueue.OnNotify 调用的事件过程}
    procedure TForm1.MyQueueNotify(Sender: TObject; const Item: Integer;
      Action: TCollectionNotification);
    begin
      
    case Action of
        cnAdded     : ShowMessageFmt(
    'Add: %d', [Item]);
        cnRemoved   : ShowMessageFmt(
    'Remove: %d', [Item]);
        cnExtracted : ShowMessageFmt(
    'Extract: %d', [Item]);
      
    end;
    end;

    procedure TForm1.Button1Click(Sender: TObject);
    var
      Queue: TQueue
    <Integer>;
    begin
      Queue :
    = TQueue<Integer>.Create();
      Queue.OnNotify :
    = MyQueueNotify;

      Queue.Enqueue(
    11); {Add: 11}
      Queue.Enqueue(
    22); {Add: 22}
      Queue.Enqueue(
    33); {Add: 33}

      Queue.Dequeue;     
    {Remove: 11}

      
    // Extract 和 Dequeue 功能一致, 区别只是在驱动 OnNotify 事件时传递的参数有区别, 没多大意义
      Queue.Extract;     
    {Extract: 22}

      
    //Queue.OnNotify := nil;

      Queue.Free;        
    {Remove: 33}
    end;

    end.
  • 相关阅读:
    C++内置类型对象之间的转换
    快速排序
    面试题7:用两个栈实现队列
    面试题6:重建二叉树
    poj 3264(线段树)
    poj 3038
    poj 并查集
    poj 1270(toposort)
    poj 2503(字符串)
    poj 3687(拓扑排序)
  • 原文地址:https://www.cnblogs.com/jxgxy/p/1596684.html
Copyright © 2011-2022 走看看