ArrayList.GetEnumerator ArrayList.GetEnumerator ArrayList.GetEnumerator ArrayList.GetEnumerator Method

Definizione

Restituisce un enumeratore che esegue l'iterazione di ArrayList.Returns an enumerator that iterates through the ArrayList.

Overload

GetEnumerator() GetEnumerator() GetEnumerator() GetEnumerator()

Restituisce un enumeratore per l'intero ArrayList.Returns an enumerator for the entire ArrayList.

GetEnumerator(Int32, Int32) GetEnumerator(Int32, Int32) GetEnumerator(Int32, Int32) GetEnumerator(Int32, Int32)

Restituisce un enumeratore per un intervallo di elementi nell'oggetto ArrayList.Returns an enumerator for a range of elements in the ArrayList.

GetEnumerator() GetEnumerator() GetEnumerator() GetEnumerator()

Restituisce un enumeratore per l'intero ArrayList.Returns an enumerator for the entire ArrayList.

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

Restituisce

Implementazioni

Esempi

L'esempio seguente ottiene l'enumeratore per un ArrayList, l'enumeratore per un intervallo di elementi e il ArrayList.The following example gets the enumerator for an ArrayList, and the enumerator for a range of elements in the ArrayList.

using System;
using System.Collections;

class Program
{
    static void Main(string[] args)
    {
        ArrayList colors = new ArrayList();
        colors.Add("red");
        colors.Add("blue");
        colors.Add("green");
        colors.Add("yellow");
        colors.Add("beige");
        colors.Add("brown");
        colors.Add("magenta");
        colors.Add("purple");

        IEnumerator e = colors.GetEnumerator();
        while (e.MoveNext())
        {
            Object obj = e.Current;
            Console.WriteLine(obj);
        }

        Console.WriteLine();

        IEnumerator e2 = colors.GetEnumerator(2, 4);
        while (e2.MoveNext())
        {
            Object obj = e2.Current;
            Console.WriteLine(obj);
        }
    }
}

/* This code example produces
   the following ouput:
    red
    blue
    green
    yellow
    beige
    brown
    magenta
    purple

    green
    yellow
    beige
    brown
 */
Imports System
Imports System.Collections

Class Program
    Private Shared Sub Main(ByVal args As String())
        Dim colors As New ArrayList()
        colors.Add("red")
        colors.Add("blue")
        colors.Add("green")
        colors.Add("yellow")
        colors.Add("beige")
        colors.Add("brown")
        colors.Add("magenta")
        colors.Add("purple")
        
        Dim e As IEnumerator = colors.GetEnumerator()
        While e.MoveNext()
            Dim obj As [Object] = e.Current
            Console.WriteLine(obj)
        End While
        
        Console.WriteLine()
        
        Dim e2 As IEnumerator = colors.GetEnumerator(2, 4)
        While e2.MoveNext()
            Dim obj As [Object] = e2.Current
            Console.WriteLine(obj)
        End While
    End Sub
End Class

' This code example produces
' the following ouput:
' red
' blue
' green
' yellow
' beige
' brown
' magenta
' purple
'
' green
' yellow
' beige
' brown
' 

Commenti

L'istruzione foreach del linguaggio C# (for each in Visual Basic) nasconde la complessità degli enumeratori.The foreach statement of the C# language (for each in Visual Basic) hides the complexity of the enumerators. Pertanto, si consiglia l'utilizzo di foreach, anziché la modifica diretta dell'enumeratore.Therefore, using foreach is recommended, instead of directly manipulating the enumerator.

È possibile utilizzare enumeratori per leggere i dati nella raccolta, ma non per modificare la raccolta sottostante.Enumerators can be used to read the data in the collection, but they cannot be used to modify the underlying collection.

Inizialmente l'enumeratore è posizionato davanti al primo elemento della raccolta.Initially, the enumerator is positioned before the first element 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 proprietà Current è indefinita.At this position, Current is undefined. Pertanto, è necessario chiamare il metodo MoveNext per spostare in avanti l'enumeratore, in corrispondenza del primo elemento della raccolta, prima di leggere il valore di Current.Therefore, you must call MoveNext to advance the enumerator to the first element 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 sull'elemento successivo.MoveNext sets Current to the next element.

Se MoveNext raggiunge la fine della raccolta, l'enumeratore è posizionato dopo l'ultimo elemento nella raccolta e MoveNext restituisce false.If MoveNext passes the end of the collection, the enumerator is positioned after the last element in the collection and MoveNext returns false. Quando l'enumeratore si trova in questa posizione, le chiamate successive a MoveNext restituire anche false.When the enumerator is at this position, subsequent calls to MoveNext also return false. Se l'ultima chiamata a MoveNext restituite false, Current è definito.If the last call to MoveNext returned false, Current is undefined. Per impostare nuovamente la proprietà Current sul primo elemento della raccolta, è possibile chiamare il metodo Reset seguito da MoveNext.To set Current to the first element 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. In caso di modifiche alla raccolta, ad esempio aggiunta, modifica o eliminazione di elementi, l'enumeratore sarà reso non valido in modo irreversibile e il comportamento corrispondente non sarà definito.If changes are made to the collection, such as adding, modifying, or deleting elements, the enumerator is irrecoverably invalidated and its behavior is undefined.

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. Per assicurare la protezione del thread durante l'enumerazione, è possibile bloccare la raccolta durante l'intera enumerazione.To guarantee thread safety during enumeration, you can lock the collection during the entire enumeration. Per consentire l'accesso alla raccolta in lettura e scrittura da parte di più thread, è necessario implementare la propria sincronizzazione.To allow the collection to be accessed by multiple threads for reading and writing, you must implement your own synchronization.

Questo metodo è un'operazione o (1).This method is an O(1) operation.

Vedi anche

GetEnumerator(Int32, Int32) GetEnumerator(Int32, Int32) GetEnumerator(Int32, Int32) GetEnumerator(Int32, Int32)

Restituisce un enumeratore per un intervallo di elementi nell'oggetto ArrayList.Returns an enumerator for a range of elements in the ArrayList.

public:
 virtual System::Collections::IEnumerator ^ GetEnumerator(int index, int count);
public virtual System.Collections.IEnumerator GetEnumerator (int index, int count);
abstract member GetEnumerator : int * int -> System.Collections.IEnumerator
override this.GetEnumerator : int * int -> System.Collections.IEnumerator
Public Overridable Function GetEnumerator (index As Integer, count As Integer) As IEnumerator

Parametri

index
Int32 Int32 Int32 Int32

Indice iniziale in base zero della sezione di ArrayList a cui l'enumeratore deve fare riferimento.The zero-based starting index of the ArrayList section that the enumerator should refer to.

count
Int32 Int32 Int32 Int32

Numero di elementi nella sezione di ArrayList a cui l'enumeratore deve fare riferimento.The number of elements in the ArrayList section that the enumerator should refer to.

Restituisce

Oggetto IEnumerator per l'intervallo di elementi specificato nell'oggetto ArrayList.An IEnumerator for the specified range of elements in the ArrayList.

Eccezioni

index è minore di zero.index is less than zero.

In alternativa-or- count è minore di zero.count is less than zero.

index e count non specificano un intervallo valido in ArrayList.index and count do not specify a valid range in the ArrayList.

Esempi

L'esempio seguente ottiene l'enumeratore per un ArrayList, l'enumeratore per un intervallo di elementi e il ArrayList.The following example gets the enumerator for an ArrayList, and the enumerator for a range of elements in the ArrayList.

using System;
using System.Collections;

class Program
{
    static void Main(string[] args)
    {
        ArrayList colors = new ArrayList();
        colors.Add("red");
        colors.Add("blue");
        colors.Add("green");
        colors.Add("yellow");
        colors.Add("beige");
        colors.Add("brown");
        colors.Add("magenta");
        colors.Add("purple");

        IEnumerator e = colors.GetEnumerator();
        while (e.MoveNext())
        {
            Object obj = e.Current;
            Console.WriteLine(obj);
        }

        Console.WriteLine();

        IEnumerator e2 = colors.GetEnumerator(2, 4);
        while (e2.MoveNext())
        {
            Object obj = e2.Current;
            Console.WriteLine(obj);
        }
    }
}

/* This code example produces
   the following ouput:
    red
    blue
    green
    yellow
    beige
    brown
    magenta
    purple

    green
    yellow
    beige
    brown
 */
Imports System
Imports System.Collections

Class Program
    Private Shared Sub Main(ByVal args As String())
        Dim colors As New ArrayList()
        colors.Add("red")
        colors.Add("blue")
        colors.Add("green")
        colors.Add("yellow")
        colors.Add("beige")
        colors.Add("brown")
        colors.Add("magenta")
        colors.Add("purple")
        
        Dim e As IEnumerator = colors.GetEnumerator()
        While e.MoveNext()
            Dim obj As [Object] = e.Current
            Console.WriteLine(obj)
        End While
        
        Console.WriteLine()
        
        Dim e2 As IEnumerator = colors.GetEnumerator(2, 4)
        While e2.MoveNext()
            Dim obj As [Object] = e2.Current
            Console.WriteLine(obj)
        End While
    End Sub
End Class

' This code example produces
' the following ouput:
' red
' blue
' green
' yellow
' beige
' brown
' magenta
' purple
'
' green
' yellow
' beige
' brown
' 

Commenti

Il foreach istruzione del linguaggio c# (for each in Visual C++, For Each Visual Basic) nasconde la complessità degli enumeratori.The foreach statement of the C# language (for each in Visual C++, For Each Visual Basic) hides the complexity of the enumerators. Pertanto, si consiglia l'utilizzo di foreach, anziché la modifica diretta dell'enumeratore.Therefore, using foreach is recommended, instead of directly manipulating the enumerator.

È possibile utilizzare enumeratori per leggere i dati nella raccolta, ma non per modificare la raccolta sottostante.Enumerators can be used to read the data in the collection, but they cannot be used to modify the underlying collection.

Inizialmente l'enumeratore è posizionato davanti al primo elemento della raccolta.Initially, the enumerator is positioned before the first element 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 proprietà Current è indefinita.At this position, Current is undefined. Pertanto, è necessario chiamare il metodo MoveNext per spostare in avanti l'enumeratore, in corrispondenza del primo elemento della raccolta, prima di leggere il valore di Current.Therefore, you must call MoveNext to advance the enumerator to the first element 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 sull'elemento successivo.MoveNext sets Current to the next element.

Se MoveNext raggiunge la fine della raccolta, l'enumeratore è posizionato dopo l'ultimo elemento nella raccolta e MoveNext restituisce false.If MoveNext passes the end of the collection, the enumerator is positioned after the last element in the collection and MoveNext returns false. Quando l'enumeratore si trova in questa posizione, le chiamate successive a MoveNext restituire anche false.When the enumerator is at this position, subsequent calls to MoveNext also return false. Se l'ultima chiamata a MoveNext restituite false, Current è definito.If the last call to MoveNext returned false, Current is undefined. Per impostare nuovamente la proprietà Current sul primo elemento della raccolta, è possibile chiamare il metodo Reset seguito da MoveNext.To set Current to the first element 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. In caso di modifiche alla raccolta, ad esempio aggiunta, modifica o eliminazione di elementi, l'enumeratore sarà reso non valido in modo irreversibile e il comportamento corrispondente non sarà definito.If changes are made to the collection, such as adding, modifying, or deleting elements, the enumerator is irrecoverably invalidated and its behavior is undefined.

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. Per assicurare la protezione del thread durante l'enumerazione, è possibile bloccare la raccolta durante l'intera enumerazione.To guarantee thread safety during enumeration, you can lock the collection during the entire enumeration. Per consentire l'accesso alla raccolta in lettura e scrittura da parte di più thread, è necessario implementare la propria sincronizzazione.To allow the collection to be accessed by multiple threads for reading and writing, you must implement your own synchronization.

Questo metodo è un'operazione o (1).This method is an O(1) operation.

Compatibilità tra versioniVersion Compatibility

In .NET Framework versioni 1.0 e 1.1, l'enumeratore per un ArrayList wrapper restituito dal Adapter metodo trattato il secondo argomento come un limite superiore anziché come un numero.In the .NET Framework versions 1.0 and 1.1, the enumerator for an ArrayList wrapper returned by the Adapter method treated the second argument as an upper bound rather than as a count. Nel .NET Framework 2.0.NET Framework 2.0 il secondo argomento in modo corretto viene considerato come un numero.In the .NET Framework 2.0.NET Framework 2.0 the second argument is correctly treated as a count.

Vedi anche

Si applica a