MaterialCollection.GetEnumerator Metodo

Definizione

Restituisce un enumeratore in grado di scorrere la raccolta.Returns an enumerator that can iterate through the collection.

public:
 System::Windows::Media::Media3D::MaterialCollection::Enumerator GetEnumerator();
public System.Windows.Media.Media3D.MaterialCollection.Enumerator GetEnumerator ();
member this.GetEnumerator : unit -> System.Windows.Media.Media3D.MaterialCollection.Enumerator
Public Function GetEnumerator () As MaterialCollection.Enumerator

Restituisce

Enumeratore in grado di scorrere l'insieme.An enumerator that can iterate the collection.

Commenti

Gli enumeratori consentono solo la lettura dei dati nella raccolta.Enumerators only allow reading the data in the collection. Non è possibile usare gli enumeratori per modificare la raccolta sottostante.Enumerators cannot be used to modify the underlying collection.

Inizialmente, l'enumeratore viene posizionato prima del primo elemento nella raccolta.Initially, the enumerator is positioned before the first item in the collection. In questa posizione, la Current chiamata a genera un'eccezione.At this position, calling Current throws an exception. Pertanto, è necessario chiamare MoveNext per far avanzare l'enumeratore al primo elemento della raccolta prima di leggere il valore di Current.Therefore, you must call MoveNext to advance the enumerator to the first item of the collection before reading the value of Current.

Current restituisce lo stesso oggetto fino a quando non Reset viene chiamato MoveNext o.Current returns the same object until either MoveNext or Reset is called. MoveNext imposta Current sull'elemento successivo.MoveNext sets Current to the next item.

Dopo aver passato la fine della raccolta, l'enumeratore viene posizionato dopo l'ultimo elemento della raccolta e la chiamata a MoveNext restituisce false.After the end of the collection is passed, the enumerator is positioned after the last item in the collection, and calling MoveNext returns false. Se l'ultima chiamata a MoveNext ha restituito false, la chiamata a Current genera un'eccezione.If the last call to MoveNext returned false, calling Current throws an exception. Per impostare nuovamente Current sul primo elemento della raccolta, è possibile chiamare Reset seguito da MoveNext.To set Current to the first item of the collection again, you can call Reset followed by MoveNext.

Un enumeratore rimane valido fino a quando la raccolta non subisce modifiche.An enumerator remains valid as long as the collection remains unchanged. Se vengono apportate modifiche alla raccolta, ad esempio l'aggiunta, la modifica o l'eliminazione di elementi, l'enumeratore viene invalidato irrimediabilmente e la successiva chiamata a MoveNext o Reset genera un'eccezione InvalidOperationException.If changes are made to the collection, such as adding, modifying or deleting items, the enumerator is irrecoverably invalidated and the next call to MoveNext or Reset throws an InvalidOperationException. Se la raccolta viene modificata tra MoveNext e Current, Current restituirà l'elemento su cui è impostato, anche se l'enumeratore è già invalidato.If the collection is modified between MoveNext and Current, Current will return the item that it is set to, even if the enumerator is already invalidated.

L'enumeratore non dispone di accesso esclusivo alla raccolta. L'enumerazione di una raccolta non è quindi una procedura thread-safe.The enumerator does not have exclusive access to the collection; therefore, enumerating through a collection is intrinsically not a thread-safe procedure. Anche quando una raccolta è sincronizzata, altri thread possono comunque modificare la raccolta, causando la generazione di un'eccezione da parte dell'enumeratore.Even when a collection is synchronized, other threads could still modify the collection, which causes the enumerator to throw an exception. Per garantire la protezione dei thread durante l'enumerazione, è possibile bloccare la raccolta per l'intera enumerazione oppure intercettare le eccezioni determinate dalle modifiche apportate da altri thread.To guarantee thread safety during enumeration, you can either lock the collection during the entire enumeration or catch the exceptions resulting from changes made by other threads.

Si applica a