WorkflowInstance.GetWorkflowQueueData Yöntem

Tanım

Bu iş akışı örneğiyle ilişkili iş akışı kuyrukları için bekleyen öğeleri ve abone olunan etkinlikleri içeren bir nesne koleksiyonunu WorkflowQueueInfo alır.

C#
public System.Collections.ObjectModel.ReadOnlyCollection<System.Workflow.Runtime.WorkflowQueueInfo> GetWorkflowQueueData();

Döndürülenler

Nesnelerden ReadOnlyCollection<T> oluşan WorkflowQueueInfo bir.

Özel durumlar

İş akışı çalışma zamanı altyapısı çalışmıyor.

Örnekler

Aşağıdaki kod örneği, bir WorkflowInstance nesneyle ilişkili tüm iş akışı kuyruklarının durumu hakkında bilgi almak için yöntemini nasıl kullanabileceğinizi GetWorkflowQueueData gösterir. Olay gerçekleştiğinde WorkflowIdled , OnWorkflowIdled bu örnekte tanımlanan yöntem çağrılır. özelliği kullanılarak hangi iş akışının WorkflowInstance boşta olduğunu belirler ve ardından yöntemini çağırarak GetWorkflowQueueData iş akışı örneği için kuyruğa alınmış öğeler koleksiyonunu alır. Kod, iş akışının boşta olduğu olayı hangi etkinliğin beklediğini belirlemek için koleksiyon üzerinde yinelenir. Ardından, olay kuyruğu öğesinin adıyla birlikte yöntemini kullanarak EnqueueItem iş akışı kuyruğuna bir özel durum gönderir.

Bu kod örneği, Program.cs dosyasından İş Akışı SDK'sını İptal Etme örneğinin bir parçasıdır. Daha fazla bilgi için bkz. İş Akışını İptal Etme.

C#
static void OnWorkflowIdled(object sender, WorkflowEventArgs e)
{
    WorkflowInstance workflow = e.WorkflowInstance;

    Console.WriteLine("\n...waiting for 3 seconds... \n");
    Thread.Sleep(3000);

    // what activity is blocking the workflow
    ReadOnlyCollection<WorkflowQueueInfo> wqi = workflow.GetWorkflowQueueData();
    foreach (WorkflowQueueInfo q in wqi)
    {
        EventQueueName eq = q.QueueName as EventQueueName;
        if (eq != null)
        {
            // get activity that is waiting for event
            ReadOnlyCollection<string> blockedActivity = q.SubscribedActivityNames;
            Console.WriteLine("Host: Workflow is blocked on " + blockedActivity[0]);

            // this event is never going to arrive eg. employee left the company
            // lets send an exception to this queue
            // it will either be handled by exception handler that was modeled in workflow
            // or the runtime will unwind running compensation handlers and exit the workflow
            Console.WriteLine("Host: This event is not going to arrive");
            Console.WriteLine("Host: Cancel workflow with unhandled exception");
            workflow.EnqueueItem(q.QueueName, new Exception("ExitWorkflowException"), null, null);
        }
    }
}

Açıklamalar

GetWorkflowQueueData , her biri WorkflowQueueInfo bu iş akışı örneğiyle ilişkili iş akışı kuyruklarından birinin durumu hakkında bilgi içeren bir nesne koleksiyonu döndürür. WorkflowQueueInfo.Items için WorkflowQueue bekleyen öğeleri içerir ve WorkflowQueueInfo.SubscribedActivityNames üzerinde öğe teslimi WorkflowQueueiçin abone olunan etkinliklerin listesini içerir.

Şunlara uygulanır

Ürün Sürümler
.NET Framework 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1

Ayrıca bkz.