Vector3DKeyFrameCollection.GetEnumerator Vector3DKeyFrameCollection.GetEnumerator Vector3DKeyFrameCollection.GetEnumerator Vector3DKeyFrameCollection.GetEnumerator Method

Definizione

Restituisce un enumeratore in grado di eseguire l'iterazione nella raccolta.Returns an enumerator that can iterate through the collection.

public:
 virtual System::Collections::IEnumerator ^ GetEnumerator();
public System.Collections.IEnumerator GetEnumerator ();
abstract member GetEnumerator : unit -> System.Collections.IEnumerator
override this.GetEnumerator : unit -> System.Collections.IEnumerator
Public Function GetEnumerator () As IEnumerator

Restituisce

Oggetto IEnumerator in grado di eseguire l'iterazione nella raccolta.An IEnumerator that can iterate through the collection.

Implementazioni

Commenti

Gli enumeratori consentono solo la lettura dei dati nella raccolta.Enumerators only allow reading the data in the collection. E non possono essere utilizzati per modificare la raccolta sottostante.Enumerators cannot be used to modify the underlying collection.

Inizialmente, l'enumeratore è posizionato prima del primo elemento nella raccolta.Initially, the enumerator is positioned before the first item in the collection. Anche il metodo Reset riporta l'enumeratore in questa posizione.Reset also brings the enumerator back to this position. In questa posizione, la chiamata a Current genera un'eccezione.At this position, calling Current throws an exception. Pertanto, è necessario chiamare MoveNext per passare 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 finché non viene chiamato il metodo MoveNext o Reset.Current returns the same object until either MoveNext or Reset is called. MoveNext imposta Current all'elemento successivo.MoveNext sets Current to the next item.

Una volta raggiunta la fine della raccolta, l'enumeratore è posizionato dopo l'ultimo elemento nella raccolta e la chiamata 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 restituite false, la chiamata Current genera un'eccezione.If the last call to MoveNext returned false, calling Current throws an exception. Per impostare Current sul primo elemento della raccolta anche in questo caso, è possibile chiamare Reset seguita 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 aggiungendo, modificando o eliminando elementi, l'enumeratore viene invalidato e alla successiva chiamata a MoveNext oppure Reset genera un 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 è stata impostata, anche se l'enumeratore risulta 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 se una raccolta è sincronizzata, altri thread è stato ancora modificare la raccolta, che fa sì che l'enumeratore generare un'eccezione.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