博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
list、set、map以及array的区别
阅读量:5358 次
发布时间:2019-06-15

本文共 663 字,大约阅读时间需要 2 分钟。

对于刚刚学习集合框架来说,如何选择list、set、map以及array是比较模糊的

在此我将对这四种情况做总结:

  • array数组,可以存储对象和基本数据类型,长度固定
  • Collection:集合(单列),用于存储对象、不能存储基本数据类型(int,char等),但可以存储基本数据类型包装类(int-Integer,char-Character等),长度可变
    • 那么,为什么会出现这么多集合呢,我们可以把集合比如成容器。每个不同容器中对数据的存储方式不同,这种存储方式称为数据结构
    List
    • :元素有序,可重复。
      • ArrayList:数组。特点:有索引(脚标),所以查找快,增删后每个元素的索引都发生改变,所以增删慢,而且数组越长增删越慢
      • LinkedList:链表。特点:无索引,每个元素都包含下一元素地址,查找需要逐一进行,所以查找慢,但是增删快只需要改变元素后面的地址。
      • Vector:线程同步数组 基本抛弃使用。
    Set
    • :元素无序,不重复,无索引。
      • HashSet:哈希表。特点:线程非同步,保证元素唯一性原理:判断hashCode是个屁相同,洗过相同在判断equals方法是否为true。
      • TreeSet:二叉树。特点:可对用两种方法对集合中元素排序,1.实现comparable接口,覆盖compareTo方法。2.集合建立时规定,并自定义比较类。
  • Map:双列集合,用于存放键值对。键值是唯一的,不可重复

转载于:https://www.cnblogs.com/ysx215/p/11346823.html

你可能感兴趣的文章
显示域初始化
查看>>
我的编程学习日志(7)--typedef的扩展
查看>>
Html/CSS 初步介绍html和css部分重要标签
查看>>
static 静态
查看>>
【剑指offer】33、二叉搜索树的后序遍历序列
查看>>
svn 基本操作
查看>>
Hyper-v虚拟机联网配置
查看>>
python链表的实现
查看>>
logging模块
查看>>
Alfresco 4.0.d 的同步多个ldap信息问题
查看>>
SpringCloud知识点20190313
查看>>
c#中的Cache缓存技术
查看>>
Oracle 给已创建的表增加自增长列
查看>>
《DSP using MATLAB》Problem 2.17
查看>>
if 循环
查看>>
uva 111 History Grading(lcs)
查看>>
Python学习week2-python介绍与pyenv安装
查看>>
php判断网页是否gzip压缩
查看>>
一个有意思的js实例,你会吗??[原创]
查看>>
sql server中bit字段实现取反操作
查看>>