I’m looking for a kind of array data-type that can easily have items added, without a performance hit.
- System.Array –
Redim Preservecopies entire RAM from old to new, as slow as amount of existing elements - System.Collections.ArrayList – good enough?
- System.Collections.IList – good enough?
Just to summarize a few data structures:
System.Collections.ArrayList: untyped data structures are obsolete. Use List(of t) instead.
System.Collections.Generic.List(of t): this represents a resizable array. This data structure uses an internal array behind the scenes. Adding items to List is O(1) as long as the underlying array hasn’t been filled, otherwise its O(n+1) to resize the internal array and copy the elements over.
Adding items is only efficient when adding to the back of the list. Inserting in the middle forces the array to shift all items forward, which is an O(n) operation. Deleting items is also O(n), since the array needs to shift items backward.
System.Collections.Generic.LinkedList(of t): if you don’t need random or indexed access to items in your list, for example you only plan to add items and iterate from first to last, then a LinkedList is your friend. Inserts and removals are O(1), lookup is O(n).