Esta documentación está archivada y no tiene mantenimiento.

List<T>.IndexOf (Método) (T, Int32)

Actualización: noviembre 2007

Busca el objeto especificado y devuelve el índice de base cero de la primera aparición dentro del intervalo de elementos de List<T> que abarca desde el índice especificado hasta el último elemento.

Espacio de nombres:  System.Collections.Generic
Ensamblado:  mscorlib (en mscorlib.dll)

public int IndexOf(
	T item,
	int index
)
public int IndexOf(
	T item,
	int index
)
public function IndexOf(
	item : T, 
	index : int
) : int

Parámetros

item
Tipo: T
Objeto que se va a buscar en List<T>. El valor puede ser null para los tipos de referencia.
index
Tipo: System.Int32
Índice inicial de base cero de la búsqueda.

Valor devuelto

Tipo: System.Int32
Índice de base cero de la primera aparición de item dentro del intervalo de elementos de List<T> que abarca desde index hasta el último elemento, si se encuentra; de lo contrario, -1.

ExcepciónCondición
ArgumentOutOfRangeException

index se encuentra fuera del intervalo de índices válidos para la colección List<T>.

La búsqueda en List<T> se realiza hacia delante, empezando en index y terminando en el último elemento.

Este método determina la igualdad utilizando el comparador de igualdad EqualityComparer<T>.Default predeterminado para T, el tipo de valores que hay en la lista.

Este método realiza una búsqueda lineal, por lo tanto, es una operación O(n), donde n es el número de elementos desde index hasta el final de List<T>.

En el ejemplo de código siguiente se muestran las tres sobrecargas del método IndexOf. Se crea un objeto List<T> de cadenas, con una entrada que aparece dos veces, en las posiciones de índice 0 y 5. La sobrecarga del método IndexOf(T) busca en la lista desde el principio y encuentra la primera aparición de la cadena. La sobrecarga del método IndexOf(T, Int32) se usa para buscar en la lista comenzando en la posición de índice 3 y continuando hasta el final de la lista, y encuentra la segunda aparición de la cadena. Por último, se utiliza la sobrecarga del método IndexOf(T, Int32, Int32) para buscar en un intervalo de dos entradas, comenzando por la posición de índice dos; devuelve –1 porque en dicho intervalo no hay instancias de la cadena buscada.

using System;
using System.Collections.Generic;

public class Example
{
    public static void Main()
    {
        List<string> dinosaurs = new List<string>();

        dinosaurs.Add("Tyrannosaurus");
        dinosaurs.Add("Amargasaurus");
        dinosaurs.Add("Mamenchisaurus");
        dinosaurs.Add("Brachiosaurus");
        dinosaurs.Add("Deinonychus");
        dinosaurs.Add("Tyrannosaurus");
        dinosaurs.Add("Compsognathus");

        Console.WriteLine();
        foreach(string dinosaur in dinosaurs)
        {
            Console.WriteLine(dinosaur);
        }

        Console.WriteLine("\nIndexOf(\"Tyrannosaurus\"): {0}", 
            dinosaurs.IndexOf("Tyrannosaurus"));

        Console.WriteLine("\nIndexOf(\"Tyrannosaurus\", 3): {0}", 
            dinosaurs.IndexOf("Tyrannosaurus", 3));

        Console.WriteLine("\nIndexOf(\"Tyrannosaurus\", 2, 2): {0}", 
            dinosaurs.IndexOf("Tyrannosaurus", 2, 2));
    }
}

/* This code example produces the following output:

Tyrannosaurus
Amargasaurus
Mamenchisaurus
Brachiosaurus
Deinonychus
Tyrannosaurus
Compsognathus

IndexOf("Tyrannosaurus"): 0

IndexOf("Tyrannosaurus", 3): 5

IndexOf("Tyrannosaurus", 2, 2): -1
 */


Windows Vista, Windows XP SP2, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP Starter Edition, Windows Server 2003, Windows Server 2000 SP4, Windows Millennium Edition, Windows 98, Windows CE, Windows Mobile para Smartphone, Windows Mobile para Pocket PC, Xbox 360

.NET Framework y .NET Compact Framework no admiten todas las versiones de cada plataforma. Para obtener una lista de las versiones compatibles, vea Requisitos de sistema de .NET Framework.

.NET Framework

Compatible con: 3.5, 3.0, 2.0

.NET Compact Framework

Compatible con: 3.5, 2.0

XNA Framework

Compatible con: 2.0, 1.0
Mostrar: