WorkflowRuntime.GetService Méthode

Définition

Surcharges

GetService(Type)

Récupère un service de l'objet Type spécifié à partir du moteur d'exécution de workflow.

GetService<T>()

Récupère un service du type générique spécifié du moteur d'exécution de workflow.

GetService(Type)

Récupère un service de l'objet Type spécifié à partir du moteur d'exécution de workflow.

C#
public object GetService(Type serviceType);

Paramètres

serviceType
Type

Type du service à récupérer.

Retours

Service de l'objet Type spécifié.

Implémente

Exceptions

serviceType est une référence Null (Nothing en Visual Basic).

L'objet WorkflowRuntime est déjà supprimé.

Plusieurs services de type serviceType ont été trouvés.

Remarques

GetService lève une InvalidOperationException si plusieurs services existent pour le Type spécifié. Par conséquent, vous devez utiliser l'une des méthodes surchargées de GetAllServices s'il est possible que plusieurs services du type spécifié soient présents dans l'objet WorkflowRuntime. Par exemple, le moteur d'exécution de workflow peut disposer de plusieurs services de suivi. Si vous demandez un service de suivi en spécifiant la classe de base TrackingService, il est possible qu'une exception soit levée.

S’applique à

.NET Framework 4.8.1 et autres versions
Produit Versions
.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

GetService<T>()

Récupère un service du type générique spécifié du moteur d'exécution de workflow.

C#
public T GetService<T>();

Paramètres de type

T

Type de service.

Retours

T

Service unique du type générique spécifié.

Exceptions

WorkflowRuntime a déjà été supprimé.

Plusieurs services de type générique ont été trouvés.

Exemples

L'exemple suivant montre comment récupérer un service unique à partir d'un objet WorkflowRuntime, dans le cas présent, un service de type ManualWorkflowSchedulerService. Cet exemple provient de l’exemple threading de flux de travail.

C#
protected override CompositeActivity OnCreateNewBranch()
{
    return new ParallelIfBranch();
}

private void OnAddBranch(object sender, EventArgs e)
{
    CompositeActivity activity1 = this.OnCreateNewBranch();
    CompositeActivity activity2 = base.Activity as CompositeActivity;

    if ((activity2 != null) && (activity1 != null))
    {
        int num1 = this.ContainedDesigners.Count;
        Activity[] activityArray1 = new Activity[] { activity1 };

        if (CanInsertActivities(new ConnectorHitTestInfo(this, HitTestLocations.Designer, activity2.Activities.Count),
            new List<Activity>(activityArray1).AsReadOnly()))
        {
            CompositeActivityDesigner.InsertActivities(this,
                new ConnectorHitTestInfo(this, HitTestLocations.Designer, activity2.Activities.Count),
                new List<Activity>(activityArray1).AsReadOnly(),
                string.Format("Adding branch {0}", activity1.GetType().Name));

            if ((this.ContainedDesigners.Count > num1) && (this.ContainedDesigners.Count > 0))
            {
                this.ContainedDesigners[this.ContainedDesigners.Count - 1].EnsureVisible();
            }
        }
    }
}

Remarques

GetService lève une InvalidOperationException si plusieurs services existent pour le type générique spécifié. Par conséquent, vous devez utiliser l'une des méthodes surchargées de GetAllServices s'il est possible que plusieurs services du type générique soient présents dans l'objet WorkflowRuntime. Par exemple, le moteur d'exécution de workflow peut disposer de plusieurs services de suivi. Si vous demandez un service de suivi en spécifiant la classe de base TrackingService, il est possible qu'une exception soit levée.

S’applique à

.NET Framework 4.8.1 et autres versions
Produit Versions
.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