【问题标题】:C# creating function queueC# 创建函数队列
【发布时间】:2012-05-23 09:43:15
【问题描述】:

我写了一个名为 QueueManager 的类:

class QueueManager
{
    Queue functionsQueue;

    public bool IsEmpty 
    { 
        get 
            {
                if (functionsQueue.Count == 0)
                    return true;
                else
                    return false;
            }
    }

    public QueueManager()
    {
        functionsQueue = new Queue();
    }

    public bool Contains(Action action)
    {
        if (functionsQueue.Contains(action))
            return true;
        else 
            return false;
    }

    public Action Pop()
    {
        return functionsQueue.Dequeue() as Action;
    }

    public void Add(Action function)
    {
        functionsQueue.Enqueue(function);
    }

    public void Add(Func<CacheObject,Boolean> function)
    {
        functionsQueue.Enqueue(function);
    }

当我创建这个类的一个实例并调用 Add 方法时,它适用于没有参数的函数,例如: functionQueue.Add(方法); ,但是当调用具有参数和返回值的方法时(在我的情况下,ClassType 作为参数,Boolean 作为返回值),例如 functionQueue.Add(Method2(classObject));它没有编译,我错过了什么?

【问题讨论】:

标签: c# .net queue action func


【解决方案1】:

因为使用functionQueue.Add(Method2(classObject)),您将呼叫结果排队,而不是呼叫本身。

要将带有参数的方法加入队列,您应该更改Add 原型以接受参数(并将它们与委托一起存储)。作为替代方案,您可以使用 lambda:

functionQueue.Add(() => Method2(classObject));

(那么你的Add 的第二次重载是没用的,你总是可以排队一个Action 在那里你提供闭包内的所有参数)。

更新
这种类型的队列的一个示例是在 WinForms 内部,从主线程以外的其他线程分派方法是使用 方法队列 完成的(查看 Control.MarshaledInvoke 的反汇编)。跳过同步和上下文,它会保留一个System.Collections.Queue,其中每个条目都是ThreadMethodEntry(用于保存所需数据的结构)。

【讨论】:

  • 哇..这实际上是有道理的..aa并且它有效:D..谢谢:D
猜你喜欢
  • 2021-01-27
  • 1970-01-01
  • 2021-02-21
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-04-19
  • 2013-12-21
  • 1970-01-01
相关资源
最近更新 更多