C# | Eliminar la entrada en el índice especificado de OrderedDictionary

El método OrderedDictionary.RemoveAt(Int32) se usa para eliminar la entrada en el índice especificado de la colección OrderedDictionary.

Sintaxis:

public void RemoveAt (int index);

Aquí, índice es el índice de base cero de la entrada que se va a eliminar.

Excepciones:

  • NotSupportedException: si la colección OrderedDictionary es de solo lectura.
  • ArgumentOutOfRangeException: si el índice es menor que cero O el índice es igual o mayor que Count.

A continuación se dan algunos ejemplos para entender la implementación de una mejor manera:

Ejemplo 1:

// C# code to remove the entry at
// the specified index from the
// OrderedDictionary
using System;
using System.Collections;
using System.Collections.Specialized;
  
class GFG {
  
    // Driver method
    public static void Main()
    {
  
        // Creating a orderedDictionary named myDict
        OrderedDictionary myDict = new OrderedDictionary();
  
        // Adding key and value in myDict
        myDict.Add("key1", "value1");
        myDict.Add("key2", "value2");
        myDict.Add("key3", "value3");
        myDict.Add("key4", "value4");
        myDict.Add("key5", "value5");
  
        // Displaying the number of element initially
        Console.WriteLine("Number of elements are : " 
                                     + myDict.Count);
  
        // Displaying the elements in myDict
        foreach(DictionaryEntry de in myDict)
            Console.WriteLine(de.Key + " -- " + de.Value);
  
        // Removing the entry at the specified
        // index from the OrderedDictionary
        myDict.RemoveAt(3);
  
        // Displaying the number of element initially
        Console.WriteLine("Number of elements are : " 
                                      + myDict.Count);
  
        // Displaying the elements in myDict
        foreach(DictionaryEntry de in myDict)
            Console.WriteLine(de.Key + " -- " + de.Value);
    }
}

Producción:

Number of elements are : 5
key1 -- value1
key2 -- value2
key3 -- value3
key4 -- value4
key5 -- value5
Number of elements are : 4
key1 -- value1
key2 -- value2
key3 -- value3
key5 -- value5

Ejemplo 2:

// C# code to remove the entry at
// the specified index from the
// OrderedDictionary
using System;
using System.Collections;
using System.Collections.Specialized;
  
class GFG {
  
    // Driver method
    public static void Main()
    {
  
        // Creating a orderedDictionary named myDict
        OrderedDictionary myDict = new OrderedDictionary();
  
        // Adding key and value in myDict
        myDict.Add("A", "Apple");
        myDict.Add("B", "Banana");
        myDict.Add("C", "Cat");
        myDict.Add("D", "Dog");
  
        // Displaying the number of element initially
        Console.WriteLine("Number of elements are : " 
                                     + myDict.Count);
  
        // Displaying the elements in myDict
        foreach(DictionaryEntry de in myDict)
            Console.WriteLine(de.Key + " -- " + de.Value);
  
        // Removing the entry at the specified
        // index from the OrderedDictionary
        // This should raise "ArgumentOutOfRangeException"
        // as index is less than 0
        myDict.RemoveAt(-2);
  
        // Displaying the number of element initially
        Console.WriteLine("Number of elements are : " 
                                     + myDict.Count);
  
        // Displaying the elements in myDict
        foreach(DictionaryEntry de in myDict)
            Console.WriteLine(de.Key + " -- " + de.Value);
    }
}

Error de tiempo de ejecución:

Excepción no controlada:
System.ArgumentOutOfRangeException: el argumento especificado estaba fuera del rango de valores válidos.
Nombre del parámetro: índice

Nota: Las entradas que siguen a la entrada eliminada se mueven hacia arriba para ocupar el lugar vacante y los índices de las entradas que se mueven también se actualizan.

Referencia:

Publicación traducida automáticamente

Artículo escrito por Sahil_Bansall y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *