一、前言:

  在c#数据结构中,集合的应用非常广泛,无论是做BS架构还是CS架构开发,都离不开集合的使用,比如我们常见的集合包括:Array、ArrayList、List、LinkedList等。这一些数据集合,在功能上都能够实现集合的存取,但是他们内部有什么区别,在使用时需要注意一些什么呢?下面根据个人的经验,对这一些集合数据的使用做一个简单的小结,如果说的不对的地方,欢迎指出,多多交流改进。

二、Array集合简介

  Array集合,也就是数组,是最简单的数据结构,其存储的数据在内存空间是连续的,数组有一下一些特点

  • 1.数据存储是连续的
  • 2.数组长度在定义时就必须制定
  • 3.数组存储的数据类型都是同一类型
  • 4.数组可以直接通过小标访问

  优缺点:
   优点:
  1、可以根据索引直接访问,访问速度快
   2、数据是安全的,由于数据类型一致性,在存储使用过程中不涉及
  缺点:
  1、由于数据是连续存储的,导致插入效率变慢
    2、由于数组长度大小固定,那么对预期非固定长度的数字不好处理

  练习实例代码:

    /// <summary>
/// 数组练习操作
/// </summary>
public class ArrayTest
{
/// 数组 Array 对于大家来说一点都不陌生
/// 数组是在内存连续分配的存储空间,这也导致数组有一下一些特点
/// 1.数据存储是连续的
/// 2.数组长度在定义时就必须制定
/// 3.数组存储的数据类型都是同一类型
/// 4.数组可以直接通过小标访问
///
/// 优缺点:
/// 优点:
/// 1、可以根据索引直接访问,访问速度快
/// 2、数据是安全的,由于数据类型一致性,在存储使用过程中不涉及到装箱拆箱操作
/// 缺点:
/// 1、由于数据是连续存储的,导致插入效率变慢
/// 2、由于数组长度大小固定,那么对预期非固定长度的数字不好处理 /// int类型的数组操作
public static void IntArrayTest()
{ //// 定义一个秒表,执行获取执行时间
Stopwatch st = new Stopwatch();//实例化类
st.Start();//开始计时 Console.WriteLine("开始初始化长度为10000000的int数组:"); //// 定义一个数组
int[] nums = new int[];
for (int i = ; i < ; i++)
{
nums[i] = + ;
} //需要统计时间的代码段 st.Stop();//终止计时
Console.WriteLine(string.Format("初始化长度为10000的int数组完毕!总耗时{0}毫秒", st.ElapsedMilliseconds.ToString()));
}
}

三、ArrayList集合简介

ArrayList 是Array的升级版,能够解决Array的一些缺点
ArrayList其内部实现也是Array,只是其长度是可以动态,在其内部用一个变量记录控制长度,ArrayList有如下一些特点

  • 1.长度不固定
  • 2.可以存储不同的数据类型(object)
  • 3.同样支持索引查询(可以直接通过小标访问)
  • 4.灵活性更强,以牺牲性能为代价

优缺点:
优点:
1、长度不固定,在定义是不必担长度溢出
2、可以存储任意数据类型
3、可根据索引查询,查询效率快
缺点:
1、由于长度不固定,执行效率低下,因为超出默认长度(10)后,会自动扩容拷贝数据,牺牲性能
2、由于存储类型是object,所以在存数据时会有装箱操作,在取数据时会有拆箱操作,影响效率
3、线程不安全,因为其内部实现是用size、array来共同控制,在新增操作时是非原子操作,所以非安全线程

使用技巧:
在实际使用过程中,为了避免自动扩容,可以预估数据长度,初始化一个数据长度,从而提高效率

练习实例代码:

    /// <summary>
/// ArrayList数组练习操作
/// </summary>
public class ArrayListTest
{
/// ArrayList 是Array的升级版,能够解决Array的一些缺点
/// ArrayList其内部实现也是Array,只是其长度是可以动态,在其内部用一个变量记录控制长度,ArrayList有如下一些特点
/// 1.长度不固定
/// 2.可以存储不同的数据类型(object)
/// 3.同样支持索引查询(可以直接通过小标访问)
/// 4.灵活性更强,以牺牲性能为代价 /// 优缺点:
/// 优点:
/// 1、长度不固定,在定义是不必担长度溢出
/// 2、可以存储任意数据类型
/// 3、可根据索引查询,查询效率快
/// 缺点:
/// 1、由于长度不固定,执行效率低下,因为超出默认长度(10)后,会自动扩容拷贝数据,牺牲性能
/// 2、由于存储类型是object,所以在存数据时会有装箱操作,在取数据时会有拆箱操作,影响效率
/// 3、线程不安全,因为其内部实现是用size、array来共同控制,在新增操作时是非原子操作,所以非安全线程
///
/// 使用技巧:
/// 在实际使用过程中,为了避免自动扩容,可以预估数据长度,初始化一个数据长度,从而提高效率 /// ArrayList操作实例
public static void ArrayListOpert()
{ //// 定义一个秒表,执行获取执行时间
Stopwatch st = new Stopwatch();//实例化类 //// 需要统计时间的代码段(统计初始化长度时的执行时间)
st.Start();//开始计时
Console.WriteLine("");
Console.WriteLine("");
Console.WriteLine("ArryList集合存储数据量为10000000,初始化一个长度,执行开始:"); ArrayList arrayList = new ArrayList(); //// 定义一个数组
for (int i = ; i < ; i++)
{
arrayList.Add( + );
} st.Stop();//终止计时
Console.WriteLine(string.Format("ArryList集合存储数据量为10000000,初始化一个长度,执行完毕:!总耗时{0}毫秒", st.ElapsedMilliseconds.ToString())); //// 需要统计时间的代码段(统计初始化非指定长度时的执行时间) st.Restart();
Console.WriteLine("");
Console.WriteLine("ArryList集合存储数据量为10000000,初始化不指定长度,执行开始:"); arrayList = new ArrayList(); //// 定义一个数组
for (int i = ; i < ; i++)
{
arrayList.Add( + );
} st.Stop();//终止计时
Console.WriteLine(string.Format("ArryList集合存储数据量为10000000,初始化不指定长度,执行完毕:!总耗时{0}毫秒", st.ElapsedMilliseconds.ToString()));
}
}

四、List集合简介

随着c#泛型的推出,为了避免ArrayList一些缺点,微软推出了List集合
List集合内部还是采用的Array实现,同时在定义时需要指定对应的数据类型
这样级保留了Array集合的优点,同时也避免了ArrayList集合的数据类型不安全和装箱带来的性能牺牲
List特点:

  • 1、数据长度不固定,自动增加
  • 2、存储相同的数据类型
  • 3、可根据索引查询,查询效率快

优缺点:
优点:
1、长度不固定,在定义是不必担长度溢出
2、存储相同数据类型的数据,避免的数据的装箱拆箱,提高了数据处理效率
3、支持索引查询,查询效率快
缺点:
1、由于长度不固定,执行效率低下,因为超出默认长度(10)后,会自动扩容拷贝数据,牺牲性能
2、线程不安全,因为其内部实现是用size、array来共同控制,在新增操作时是非原子操作,所以非安全线程

练习实例代码:

   /// <summary>
/// List练习操作
/// </summary>
public class ListTest
{
/// 随着c#泛型的推出,为了避免ArrayList一些缺点,微软推出了List集合
/// List集合内部还是采用的Array实现,同时在定义时需要指定对应的数据类型
/// 这样级保留了Array集合的优点,同时也避免了ArrayList集合的数据类型不安全和装箱带来的性能牺牲
/// List特点:
/// 1、数据长度不固定,自动增加
/// 2、存储相同的数据类型
/// 3、可根据索引查询,查询效率快
///
/// 优缺点:
/// 优点:
/// 1、长度不固定,在定义是不必担长度溢出
/// 2、存储相同数据类型的数据,避免的数据的装箱拆箱,提高了数据处理效率
/// 3、支持索引查询,查询效率快
/// 缺点:
/// 1、由于长度不固定,执行效率低下,因为超出默认长度(10)后,会自动扩容拷贝数据,牺牲性能
/// 2、线程不安全,因为其内部实现是用size、array来共同控制,在新增操作时是非原子操作,所以非安全线程 /// ArrayList操作实例
public static void ListOpert()
{
//// 定义一个秒表,执行获取执行时间
Stopwatch st = new Stopwatch();//实例化类
st.Start();//开始计时
//// 需要统计时间的代码段(统计初始化长度时的执行时间)
Console.WriteLine("");
Console.WriteLine("");
Console.WriteLine("List集合存储数据量为10000000,初始化一个长度,执行开始:"); List<int> list = new List<int>(); //// 定义一个数组
for (int i = ; i < ; i++)
{
list.Add( + );
} //需要统计时间的代码段 st.Stop();//终止计时
Console.WriteLine(string.Format("List集合存储数据量为10000000,初始化一个长度,执行完毕:!总耗时{0}毫秒", st.ElapsedMilliseconds.ToString())); //// 需要统计时间的代码段(统计初始化非指定长度时的执行时间)
st.Restart();
Console.WriteLine("");
Console.WriteLine("List集合存储数据量为10000000,初始化不指定长度,执行开始:"); list = new List<int>(); //// 定义一个数组
for (int i = ; i < ; i++)
{
list.Add( + );
} st.Stop();//终止计时
Console.WriteLine(string.Format("List集合存储数据量为10000000,初始化不指定长度,执行完毕:!总耗时{0}毫秒", st.ElapsedMilliseconds.ToString()));
}
}

五、LinkedList集合简介

LinkedList链表的底层是采用双向链表的方式实现,
在链表(Linked List)中,每一个元素都指向下一个元素,以此来形成了一个链(chain)
可以从头部和尾部插入数据,在存储内存上采用非连续方式存储,链表有如下一些特点

  • 1、内存存储上是非连续的
  • 2、能够支持从头部和底部同时插入
  • 3、长度是非固定的

优缺点:
优点:
1、由于非连续存储,中部插入和删除元素效率高
2、长度非固定,在创建时不用考虑其长度
3、可以冲头部和底部添加元素
4、数据类型是安全的,在创建时需要指定的数据类型
缺点:
1、由于非连续存储,不能通过小标访问,查询效率低

练习实例代码:

    /// <summary>
/// LinkedList练习操作
/// </summary>
public class LinkedListTest {
/// LinkedList链表的底层是采用双向链表的方式实现,
/// 在链表(Linked List)中,每一个元素都指向下一个元素,以此来形成了一个链(chain)
/// 可以从头部和尾部插入数据,在存储内存上采用非连续方式存储,链表有如下一些特点
/// 1、内存存储上是非连续的
/// 2、能够支持从头部和底部同时插入
/// 3、长度是非固定的
/// 优缺点:
/// 优点:
/// 1、由于非连续存储,中部插入和删除元素效率高
/// 2、长度非固定,在创建时不用考虑其长度
/// 3、可以冲头部和底部添加元素
/// 4、数据类型是安全的,在创建时需要指定的数据类型
/// 缺点:
/// 1、由于非连续存储,不能通过小标访问,查询效率低 /// LinkedList操作实例
public static void LinkedListTestOpert() {
//// 定义一个秒表,执行获取执行时间
Stopwatch st = new Stopwatch();//实例化类
st.Start();//开始计时
//// 需要统计时间的代码段(统计初始化长度时的执行时间)
Console.WriteLine("");
Console.WriteLine("");
Console.WriteLine("Linked集合存储数据量为10000000,执行开始:"); LinkedList<int> list = new LinkedList<int>(); //// 定义一个数组
for (int i = ; i < ; i++)
{
list.AddFirst( + );
} //需要统计时间的代码段 st.Stop();//终止计时
Console.WriteLine(string.Format("Linked集合存储数据量为10000000,执行完毕:!总耗时{0}毫秒", st.ElapsedMilliseconds.ToString()));
}
}

六、每种集合数据执行结果对比分析

    class Program
{
static void Main(string[] args)
{
//// array数组操作测试
ArrayTest.IntArrayTest(); //// arrayList集合操测试
ArrayListTest.ArrayListOpert(); //// List集合操作测试
ListTest.ListOpert(); //// LinkedList集合操作测试
LinkedListTest.LinkedListTestOpert(); ///// 通过测试数据
//通过测试数据大概可以分析得出一些结论
//1、整体效率上Array效率最高,ArrayList效率最低,List效率介于Array和ArrayList之间
//2、ArrayList和List集合,在定义时如果知道数据长度,那么初始化时,指定长度的效率比不指定的长度效率高 //总结:
//在数据集合使用选择上给出以下一些建议:
//1、Array:当元素的数量是固定的,并且需要使用下标时
//2、ArrayList:当存储的元素类型不同时
//3、List:当元素的数量是固定的,并且需要使用下标时
//4、LinkedList:当元素需要能够在列表的两端添加时
Console.ReadLine();
}
}

  执行结果数据

通过测试数据大概可以分析得出一些结论
1、整体效率上Array效率最高,ArrayList效率最低,List效率介于Array和ArrayList之间
2、ArrayList和List集合,在定义时如果知道数据长度,那么初始化时,指定长度的效率比不指定的长度效率高

七、总结:

在数据集合使用选择上给出以下一些建议:
1、Array:当元素的数量是固定的,并且需要使用下标时
2、ArrayList:当存储的元素类型不同时,初始化时给一个预估的长度
3、List:当元素的数量是固定的,并且需要使用下标时,初始化时给一个预估的长度
4、LinkedList:当元素需要能够在列表的两端添加时

附件:

关于这一些练习的代码,上传到github,有兴趣的可以看一下:

https://github.com/xuyuanhong0902/dataStructureTest.git

c#数据结构之Array、ArrayList、List、LinkedList对比分析的更多相关文章

  1. Java中arraylist和linkedlist源代码分析与性能比較

    Java中arraylist和linkedlist源代码分析与性能比較 1,简单介绍 在java开发中比較经常使用的数据结构是arraylist和linkedlist,本文主要从源代码角度分析arra ...

  2. List集合总结,对比分析ArrayList,Vector,LinkedList

    前面已经写了三篇关于Java集合的文章,包括: Java集合 ArrayList原理及使用 再说Java集合,subList之于ArrayList Java集合 LinkedList的原理及使用 关于 ...

  3. [源码分析]ArrayList和LinkedList如何实现的?我看你还有机会!

    文章已经收录在 Github.com/niumoo/JavaNotes ,更有 Java 程序员所需要掌握的核心知识,欢迎Star和指教. 欢迎关注我的公众号,文章每周更新. 前言 说真的,在 Jav ...

  4. Java数据结构之表的增删对比---ArrayList与LinkedList之一

    一.Java_Collections表的实现 与c不同Java已经实现并封装了现成的表数据结构,顺序表以及链表. 1.ArrayList是基于数组的实现,因此具有的特点是:1.有索引值方便查找,对于g ...

  5. ArrayList和LinkedList的几种循环遍历方式及性能对比分析(转)

    主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性能测试对比,根据ArrayList和LinkedList的源码实现分析性能结果,总结结论. 通过本文你可以 ...

  6. ArrayList和LinkedList的几种循环遍历方式及性能对比分析

    最新最准确内容建议直接访问原文:ArrayList和LinkedList的几种循环遍历方式及性能对比分析 主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性 ...

  7. ArrayList和LinkedList的几种循环遍历方式及性能对比分析(转载)

    原文地址: http://www.trinea.cn/android/arraylist-linkedlist-loop-performance/ 原文地址: http://www.trinea.cn ...

  8. ArrayList和LinkedList遍历方式及性能对比分析

    ArrayList和LinkedList的几种循环遍历方式及性能对比分析 主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性能测试对比,根据ArrayLis ...

  9. 【转】ArrayList和LinkedList的几种循环遍历方式及性能对比分析

    原文网址:http://www.trinea.cn/android/arraylist-linkedlist-loop-performance/ 主要介绍ArrayList和LinkedList这两种 ...

随机推荐

  1. 公共DNS性能大比拼

    ​ 今天中午,访问Gitee突然访问不进去,然后收到红薯通知:阿里云停止了 Gitee.com 的域名解析. ​ ​ 码云官方也随后给出解决办法 没有任何提示,没有任何提前通知,阿里云停止了 Gite ...

  2. 使用java语言实现一个动态数组(详解)(数据结构)

    废话不多说,上代码 1.从类名开始(我真是太贴心了) public class Array<E> 首先数组类需要带有泛型,这个不多说.需要注意的是在java中,数组只能存放同一个类型的. ...

  3. [Luogu2458][SDOI2006]保安站岗

    题目描述 五一来临,某地下超市为了便于疏通和指挥密集的人员和车辆,以免造成超市内的混乱和拥挤,准备临时从外单位调用部分保安来维持交通秩序. 已知整个地下超市的所有通道呈一棵树的形状:某些通道之间可以互 ...

  4. 一起来看一下Java中的Annotation注解

    目录: 一. 什么是Annotation 二. Annotation的作用 2.1 编译器使用到的注解 2.2 .class文件使用到的注解 2.3 运行期读取的注解 三. 定义Annotation ...

  5. Head First设计模式——装饰者模式

    前言:对于设计模式我们有时候在想是否有必要,因为实际开发中我们没有那么多闲工夫去套用这么多设计模式,也没有必要为了模式而模式. 通常这些模式会引入新的抽象层,增加代码的复杂度,但是当我们掌握了这些设计 ...

  6. 记因git规范导致的提测和发布延迟

    号外 最近因为换工作的原因,我的博客和Github没有像之前那样频繁的更新了.一方面原因是投递简历和准备面试,由于之前的基础没有很扎实,需要把平时的知识点都整理一遍.这个时间段持续了20多天的样子,因 ...

  7. MongoDB系列---入门安装操作

    MongoDB 学习大纲: 1.MongoDB简介与其它数据库对比以及数据类型 2.MongoDB安装 3.MongoDB简单操作 环境要求: Linux 一.MongoDB简介 1 什么是Mongo ...

  8. vue 开发插件流程

    UI demo UI 插件汇总 我的github iSAM2016 在练习写UI组件的,用到全局的插件,网上看了些资料.看到些的挺好的,我也顺便总结一下写插件的流程: 声明插件-> 写插件-&g ...

  9. 设计模式(十八)Memento模式

    在使用面向对象编程的方式实现撤销功能时,需要事先保存实例的相关状态信息.然后,在撤销时,还需要根据所保存的信息将实例恢复至原来的状态. 要想恢复实例,需要一个可以自由访问实例内部结构的权限.但是,如果 ...

  10. jquery复习

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...