数组型:

Array:内存连续分配,长度不可变,可索引访问。

ArrayList:早期版本使用,非泛型,类型不安全,如果元素数据类型不同可考虑使用。

List<>:泛型,可变长度,内存连续分配,只要内存是连续分配的都可以使用索引访问。

以上三种数据类型都是内存连续的,所以可以使用索引访问,增删改慢,索引查询快,实现IList、ICollection接口

 

链表型:

LinkedList<>:双向链表,元素不连续,所以不能使用索引访问,只能遍历查找,查找效率低,增删效率高。

Queue:先进先出,队列使用,可使用ConcurrentQueue保证线程安全

Stack:先进后出,可使用ConcurrentStack保证线程安全

以上三种数据类型内存不连续,所以不可以使用索引访问,增删改快,查慢,实现ICollection接口。

 

集合型:
Hashtable:老版本中使用,非泛型,线程安全,浪费空间

Hashset:查询效率高,所以如果元素较多,有查询需求,使用此类型。

Dictionary<>:非线程安全,可以使用ConcurrentDictionary

Hash分布,元素间没有关系,key不可重复。增删改查都快

SortedSet

 

List与HashSet查询性能比较:

static void Main(string[] args)
        {
            List<Geography> geoList = new List<Geography>();
            HashSet<Geography> geoSet = new HashSet<Geography>();
            //添加30W测试数据
            for (int i = 0; i < 500000; i++)
            {
                geoSet.Add(new Geography { ID=i,Name="beijing",Type=2});
                geoList.Add(new Geography { ID = i, Name = "beijing", Type = 2 });
            }
            geoSet.Add(new Geography { ID = 100001, Name = "USA", Type = 1 });
            geoList.Add(new Geography { ID = 100001, Name = "USA", Type = 1 });

            Stopwatch sw = new Stopwatch();
            sw.Start();
            var item =geoList.FirstOrDefault(g => g.Name == "USA" && g.Type==1);
            sw.Stop();
           
            Console.WriteLine($"list耗时{ sw.ElapsedMilliseconds}");//list耗时13ms

            sw.Reset();
            item = geoSet.First(g => g.Name == "USA" && g.Type == 1);
            sw.Stop();
            Console.WriteLine($"set耗时{sw.ElapsedMilliseconds}");//set耗时0ms


            Console.ReadKey();
        }
    }
    public class Geography
    {
        public long ID { get; set; }
        public string Name { get; set; }
        public int Type { get; set; }

    }