ActivityCollection.GetEnumerator 메서드

정의

에 대한 열거형 인터페이스를 ICollection구현합니다.

public:
 System::Collections::Generic::IEnumerator<System::Workflow::ComponentModel::Activity ^> ^ GetEnumerator();
public System.Collections.Generic.IEnumerator<System.Workflow.ComponentModel.Activity> GetEnumerator();
override this.GetEnumerator : unit -> System.Collections.Generic.IEnumerator<System.Workflow.ComponentModel.Activity>
Public Function GetEnumerator () As IEnumerator(Of Activity)

반품

인스턴스를 반복할 ReadOnlyCollectionBase 수 있는 열거자입니다.

구현

설명

열거자는 컬렉션의 데이터만 읽을 수 있습니다. 열거자를 사용하여 기본 컬렉션을 수정할 수 없습니다.

시작하려면 열거자가 컬렉션의 첫 번째 요소 앞에 배치됩니다. Reset 또한 열거자를 이 위치로 다시 가져옵니다. 이 위치에서 호출 Current 하면 예외가 발생합니다. 따라서 값을 MoveNext읽기 전에 열거자를 컬렉션의 첫 번째 요소로 이동하도록 호출 Current 해야 합니다.

Current 는 호출될 때까지 동일한 개체를 MoveNextReset 반환합니다. MoveNext 는 다음 요소로 설정 Current 됩니다.

컬렉션의 끝을 전달한 후 열거자는 컬렉션의 마지막 요소 다음으로 배치되고 호출 MoveNext 은 반환됩니다 false. 반환MoveNextfalse 마지막 호출이 있으면 호출 Current 에서 예외가 발생합니다.

컬렉션의 첫 번째 요소로 다시 설정 Current 하려면 다음Reset을 호출 MoveNext 할 수 있습니다.

컬렉션이 변경되지 않은 상태로 유지되는 한 열거자는 유효한 상태로 유지됩니다. 요소 추가, 수정 또는 삭제와 같이 컬렉션이 변경된 경우 열거자는 취소할 수 없게 무효화되고 다음 호출을 수행 MoveNext 하거나 Reset 발생합니다 InvalidOperationException . 컬렉션이 수정된 경우 MoveNextCurrentCurrent 열거자가 이미 무효화된 경우에도 컬렉션이 설정된 요소를 반환합니다.

열거자는 컬렉션에 대한 단독 액세스 권한이 없습니다. 따라서 컬렉션을 열거하는 것은 본질적으로 스레드로부터 안전한 프로시저가 아닙니다. 컬렉션이 동기화된 경우에도 다른 스레드는 컬렉션을 수정할 수 있습니다. 이로 인해 열거자가 예외를 발생합니다. 열거 중 스레드 안전을 보장하기 위해 전체 열거 중에 컬렉션을 잠그거나 다른 스레드의 변경으로 인한 예외를 catch할 수 있습니다.

적용 대상