StringCollection.Insert(Int32, String) Method  
Definition
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Inserts a string into the StringCollection at the specified index.
public:
 void Insert(int index, System::String ^ value);public void Insert(int index, string value);public void Insert(int index, string? value);member this.Insert : int * string -> unitPublic Sub Insert (index As Integer, value As String)Parameters
- index
- Int32
The zero-based index at which value is inserted.
- value
- String
The string to insert. The value can be null.
Exceptions
Examples
The following code example adds new elements to the StringCollection.
using System;
using System.Collections;
using System.Collections.Specialized;
public class SamplesStringCollection  {
   public static void Main()  {
      // Creates and initializes a new StringCollection.
      StringCollection myCol = new StringCollection();
      Console.WriteLine( "Initial contents of the StringCollection:" );
      PrintValues( myCol );
      // Adds a range of elements from an array to the end of the StringCollection.
      String[] myArr = new String[] { "RED", "orange", "yellow", "RED", "green", "blue", "RED", "indigo", "violet", "RED" };
      myCol.AddRange( myArr );
      Console.WriteLine( "After adding a range of elements:" );
      PrintValues( myCol );
      // Adds one element to the end of the StringCollection and inserts another at index 3.
      myCol.Add( "* white" );
      myCol.Insert( 3, "* gray" );
      Console.WriteLine( "After adding \"* white\" to the end and inserting \"* gray\" at index 3:" );
      PrintValues( myCol );
   }
   public static void PrintValues( IEnumerable myCol )  {
      foreach ( Object obj in myCol )
         Console.WriteLine( "   {0}", obj );
      Console.WriteLine();
   }
}
/*
This code produces the following output.
Initial contents of the StringCollection:
After adding a range of elements:
   RED
   orange
   yellow
   RED
   green
   blue
   RED
   indigo
   violet
   RED
After adding "* white" to the end and inserting "* gray" at index 3:
   RED
   orange
   yellow
   * gray
   RED
   green
   blue
   RED
   indigo
   violet
   RED
   * white
*/
Imports System.Collections
Imports System.Collections.Specialized
Public Class SamplesStringCollection   
   Public Shared Sub Main()
      ' Creates and initializes a new StringCollection.
      Dim myCol As New StringCollection()
      Console.WriteLine("Initial contents of the StringCollection:")
      PrintValues(myCol)
      ' Adds a range of elements from an array to the end of the StringCollection.
      Dim myArr() As [String] = {"RED", "orange", "yellow", "RED", "green", "blue", "RED", "indigo", "violet", "RED"}
      myCol.AddRange(myArr)
      Console.WriteLine("After adding a range of elements:")
      PrintValues(myCol)
      ' Adds one element to the end of the StringCollection and inserts another at index 3.
      myCol.Add("* white")
      myCol.Insert(3, "* gray")
      Console.WriteLine("After adding ""* white"" to the end and inserting ""* gray"" at index 3:")
      PrintValues(myCol)
   End Sub
   Public Shared Sub PrintValues(myCol As IEnumerable)
      Dim obj As [Object]
      For Each obj In  myCol
         Console.WriteLine("   {0}", obj)
      Next obj
      Console.WriteLine()
   End Sub
End Class
'This code produces the following output.
'
'Initial contents of the StringCollection:
'
'After adding a range of elements:
'   RED
'   orange
'   yellow
'   RED
'   green
'   blue
'   RED
'   indigo
'   violet
'   RED
'
'After adding "* white" to the end and inserting "* gray" at index 3:
'   RED
'   orange
'   yellow
'   * gray
'   RED
'   green
'   blue
'   RED
'   indigo
'   violet
'   RED
'   * white
'
Remarks
Duplicate strings are allowed in StringCollection.
If index is equal to Count, value is added to the end of StringCollection.
In collections of contiguous elements, such as lists, the elements that follow the insertion point move down to accommodate the new element. If the collection is indexed, the indexes of the elements that are moved are also updated. This behavior does not apply to collections where elements are conceptually grouped into buckets, such as a hash table.
This method is an O(n) operation, where n is Count.