Here's what I've found (ignoring the old non-generic collections):

  • Array - C array, though the .NET Array can have a non-zero starting index.
  • List<T> - std::vector<T>
  • Dictionary<TKey, TValue> - unordered_map<Key, Data>
  • HashSet<T> - unordered_set<Key>
  • SortedDictionary<TKey, TValue> - std::map<Key, Data>
  • SortedList<TKey, TValue> - equivalent to a std::vector<T> but keeping it ordered by using binary search + insert when adding elements.
  • SortedSet<T> - std::set<Key>
  • Queue<T> - std::queue<T>
  • Stack<T> - std::stack<T>
  • LinkedList<T> - std::list<T>

Notably missing from the .NET collections are the "multi-" variants, e.g., multisetmultimap, etc. However, they have added a number of very useful threadsafe collections: the "Concurrent-" variants, e.g., ConcurrentDictionaryConcurrentQueue, etc.

posted on 2016-07-03 21:31  今夜太冷  阅读(404)  评论(0)    收藏  举报