ParallelForEach<T> ParallelForEach<T> ParallelForEach<T> ParallelForEach<T> Class

Definition

Перечисляет элементы коллекции и выполняет внедренную инструкцию для каждого элемента коллекции параллельно. Enumerates the elements of a collection and executes an embedded statement for each element of the collection in parallel.

generic <typename T>
public ref class ParallelForEach sealed : System::Activities::NativeActivity
[System.Windows.Markup.ContentProperty("Body")]
public sealed class ParallelForEach<T> : System.Activities.NativeActivity
type ParallelForEach<'T> = class
    inherit NativeActivity
Public NotInheritable Class ParallelForEach(Of T)
Inherits NativeActivity

Type Parameters

T

Тип значений в коллекции Values. The type of the values provided in the Values collection.

Inheritance
Attributes

Examples

В следующем образце кода показано создание действия ParallelForEach<T>.The following code sample demonstrates creating a ParallelForEach<T> activity. Этот пример взят из процесс корпоративных закупок образца.This example is from the Corporate Purchase Process sample.

// invite all vendors and wait for their proposals
new ParallelForEach<Vendor>
{
    DisplayName = "Get vendor proposals",
    Values = new InArgument<IEnumerable<Vendor>>(ctx =>this.Rfp.Get(ctx).InvitedVendors),
    Body = new ActivityAction<Vendor>()
    {                                    
        Argument = iterationVariableVendor,
        Handler = new Sequence
        {
            Variables = { tmpValue },
            Activities =
            {
                // waits for a vendor proposal (creates a bookmark for a vendor)
                new WaitForVendorProposal 
                { 
                    VendorId = new LambdaValue<int>(ctx =>iterationVariableVendor.Get(ctx).Id) ,
                    Result = new OutArgument<double>(tmpValue)
                },

                // after the vendor proposal is received, it is registered in the Request for Proposals
                new InvokeMethod
                {
                    TargetObject = new InArgument<RequestForProposal>(ctx =>this.Rfp.Get(ctx)),
                    MethodName = "RegisterProposal",
                    Parameters = 
                    {
                        new InArgument<Vendor>(iterationVariableVendor),
                        new InArgument<double>(tmpValue)
                    }
                },
            }
        }                        
    }
},

Remarks

Внедренные инструкции планируются совместно и выполняются асинхронно, однако если сами запланированные действия не являются асинхронными (например, действия по обмену сообщениями, InvokeMethod или действия, производные от AsyncCodeActivity), то они не выполняются в отдельных потоках и каждое последующее действие выполняется только после того, как предыдущее запланированное действие завершается или переходит в режим бездействия.The embedded statements are scheduled together and run asynchronously, but unless the scheduled activites themselves are asynchronous (such as messaging activities, InvokeMethod, or activities that derive from AsyncCodeActivity), they do not run on separate threads, so each successive activity will only execute when the previously scheduled activity completes or goes idle. Если ни одно из дочерних действий этого действия не является асинхронным и не бездействует, то это действие выполняется так же, как действие ForEach<T>.If none of the child activities of this activity are asynchronous or go idle, this activity execute in the same way that a ForEach<T> activity does.

Constructors

ParallelForEach<T>() ParallelForEach<T>() ParallelForEach<T>() ParallelForEach<T>()

Создает новый экземпляр класса ParallelForEach<T>. Creates a new instance of the ParallelForEach<T> class.

Properties

Body Body Body Body

Объект ActivityAction, который однократно выполняется для каждого значения, содержащегося в коллекции свойств Values. The ActivityAction that is executed once for every value contained in the Values collection.

CacheId CacheId CacheId CacheId

Возвращает идентификатор кэша, уникальный в пределах области определения рабочего процесса. Gets the identifier of the cache that is unique within the scope of the workflow definition.

(Inherited from Activity)
CanInduceIdle CanInduceIdle CanInduceIdle CanInduceIdle

Возвращает или задает значение, указывающее, может ли действие вызывать простой рабочего процесса. Gets or sets a value that indicates whether the activity can cause the workflow to become idle.

(Inherited from NativeActivity)
CompletionCondition CompletionCondition CompletionCondition CompletionCondition

Оценивается после каждого выполнения итерации. Evaluated after each iteration completes.

Constraints Constraints Constraints Constraints

Возвращает коллекцию действий Constraint, которые можно настроить для выполнения проверки the Activity. Gets a collection of Constraint activities that can be configured to provide validation for the Activity.

(Inherited from Activity)
DisplayName DisplayName DisplayName DisplayName

Возвращает или задает дополнительное понятное имя, используемое для отладки, проверки, обработки исключений и отслеживания. Gets or sets an optional friendly name that is used for debugging, validation, exception handling, and tracking.

(Inherited from Activity)
Id Id Id Id

Возвращает идентификатор, уникальный в пределах области определения рабочего процесса. Gets an identifier that is unique in the scope of the workflow definition.

(Inherited from Activity)
Implementation Implementation Implementation Implementation

Логика выполнения действия. The execution logic of the activity.

(Inherited from NativeActivity)
ImplementationVersion ImplementationVersion ImplementationVersion ImplementationVersion

Получает или задает версию реализации действия. Gets or sets the implementation version of the activity.

(Inherited from NativeActivity)
Values Values Values Values

Коллекция значений, используемых в качестве параметров для каждой итерации действия, которое содержится в свойстве Body. The collection of values used as parameters for each iteration of the activity contained in the Body.

Methods

Abort(NativeActivityAbortContext) Abort(NativeActivityAbortContext) Abort(NativeActivityAbortContext) Abort(NativeActivityAbortContext)

При реализации в производном классе выполняет действия в ответ на прерывание действия. When implemented in a derived class, takes actions in response to the activity being aborted.

(Inherited from NativeActivity)
CacheMetadata(ActivityMetadata) CacheMetadata(ActivityMetadata) CacheMetadata(ActivityMetadata) CacheMetadata(ActivityMetadata)

Не реализован. Not implemented. Взамен рекомендуется использовать метод CacheMetadata(NativeActivityMetadata). Use the CacheMetadata(NativeActivityMetadata) method instead.

(Inherited from NativeActivity)
CacheMetadata(NativeActivityMetadata) CacheMetadata(NativeActivityMetadata) CacheMetadata(NativeActivityMetadata) CacheMetadata(NativeActivityMetadata)

Создает и проверяет описание аргументов, переменных, дочерних действий и делегатов действия. Creates and validates a description of the activity’s arguments, variables, child activities, and activity delegates.

(Inherited from NativeActivity)
Cancel(NativeActivityContext) Cancel(NativeActivityContext) Cancel(NativeActivityContext) Cancel(NativeActivityContext)

При реализации в производном классе выполняет логику, обеспечивающую изящное раннее завершение действия. When implemented in a derived class, runs logic to cause graceful early completion of the activity.

(Inherited from NativeActivity)
Equals(Object) Equals(Object) Equals(Object) Equals(Object)

Определяет, равен ли заданный объект текущему объекту. Determines whether the specified object is equal to the current object.

(Inherited from Object)
Execute(NativeActivityContext) Execute(NativeActivityContext) Execute(NativeActivityContext) Execute(NativeActivityContext)

При реализации в производном классе запускает логику выполнения действия. When implemented in a derived class, runs the activity’s execution logic.

(Inherited from NativeActivity)
GetHashCode() GetHashCode() GetHashCode() GetHashCode()

Служит хэш-функцией по умолчанию. Serves as the default hash function.

(Inherited from Object)
GetType() GetType() GetType() GetType()

Возвращает объект Type для текущего экземпляра. Gets the Type of the current instance.

(Inherited from Object)
MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

Создает неполную копию текущего объекта Object. Creates a shallow copy of the current Object.

(Inherited from Object)
OnCreateDynamicUpdateMap(NativeActivityUpdateMapMetadata, Activity) OnCreateDynamicUpdateMap(NativeActivityUpdateMapMetadata, Activity) OnCreateDynamicUpdateMap(NativeActivityUpdateMapMetadata, Activity) OnCreateDynamicUpdateMap(NativeActivityUpdateMapMetadata, Activity)

Вызывает событие при создании сопоставления для динамического обновления. Raises an event when creating a map for the dynamic update.

(Inherited from NativeActivity)
OnCreateDynamicUpdateMap(UpdateMapMetadata, Activity) OnCreateDynamicUpdateMap(UpdateMapMetadata, Activity) OnCreateDynamicUpdateMap(UpdateMapMetadata, Activity) OnCreateDynamicUpdateMap(UpdateMapMetadata, Activity)

Вызывает событие при создании сопоставления для динамического обновления. Raises an event when creating a map for the dynamic update.

(Inherited from NativeActivity)
ShouldSerializeDisplayName() ShouldSerializeDisplayName() ShouldSerializeDisplayName() ShouldSerializeDisplayName()

Указывает, необходима ли сериализация свойства DisplayName. Indicates whether the DisplayName property should be serialized.

(Inherited from Activity)
ToString() ToString() ToString() ToString()

Возвращает значение типа String, которое содержит Id и DisplayName для Activity. Returns a String that contains the Id and DisplayName of the Activity.

(Inherited from Activity)
UpdateInstance(NativeActivityUpdateContext) UpdateInstance(NativeActivityUpdateContext) UpdateInstance(NativeActivityUpdateContext) UpdateInstance(NativeActivityUpdateContext)

Обновляет экземпляр NativeActivity. Updates the instance of NativeActivity.

(Inherited from NativeActivity)

Applies to