热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

黑马程序员-java的集合概念:Coleection,List,Map,Set之间的关系

提问:Coleection,List,Map,Set之间的关系。这篇文章,是在黑马基础测试阶段形成的。。。通过查找资料和API,形成下文。也许我的思考是错误的,但是是我思考的结果。不过确实有可能是盲

 

提问:Coleection,List,Map,Set之间的关系。

这篇文章,是在黑马基础测试阶段形成的。。。

通过查找资料和API,形成下文。也许我的思考是错误的,但是是我思考的结果。不过确实有可能是盲人摸象,显得断章取义了,因为没有统领到java整个框架架构里考虑。以后学习了整体有了框架感觉,回头再看吧。

废话不多说,以下是正文:

java中的集合概念有多重形式,而这些形式都是因为对处理数据的方式和方法不同而区分,也即数据结构。有四种形式:Coleection,List,Map,Set。(说到数据结构,想起学过的堆栈,链表,二分搜索,哈希树,数组。。)

一种是集合Collection,用来存放一组对立的元素,通常这些元素都服从某些规则,且每个位置只能保存一个元素,元素之间没有指定的关系,允许重复元素;

一种是列表List,List是有序的 Collection,用来存放多个元素,它能够维护元素的次序,并且允许元素重复;次序是 List 最重要的特点:它保证维护元素特定的顺序。

一种是集合Set,Set是一个不包含重复元素的Collection,它也可以存放多个元素,但是不允许元素重复,且不维护元素的顺序; Set只关心某元素是否属于 Set(不允许有相同元素),而不关心它的顺序。

一种是映射Map,它存储键/值对,即映射。根据键得到值,因此不允许键重复,但允许值重复。

四者还有如下分支结构(其实想画框架图的):

Collection有三个子接口:List,Set,Map.

三个子接口又各有其实现类:

List提供了3个实现类:ArrayList、Vector和LinkedList.

Set提供了3个实现类:HashSet、LinkedHashSet和TreeSet

Map提供了4个实现类:HashMap、Hashtable、LinkedHashMap和TreeMap

List实现类分析:

ArrayList是最常用的List实现类,内部是通过数组实现的,它允许对元素进行快速随机访问。数组的缺点就是每个元素之间不能含有“空隙”,当数组大小不满足需要增加存储能力,就要将已有数组数据复制到新的存储空间中,当从ArrayList的中间位置插入或者删除元素时,需要对数组进行复制、移动,代价比较高。所以,ArrayList适合随机查找和遍历,不适合插入和删除。

Vector也是通过数组实现的,不同的是它支持线程同步,即某一刻只能有一个线程能够写Vector,避免了多线程同时写而导致的不一致性,但实现同步需要很高的花费,因此访问Vector比访问ArrayList慢。

LinkedList是用链表结构存储数据的,很适合数据的动态插入和删除,随机访问和遍历速度较慢。另外,它还提供了List接口中没有定义的方法,专门用于操作表头和表尾元素,可以当做堆栈、队列和双向队列使用。

Set实现类分析:

HashSet采用散列函数对元素进行排序,是专门为快速查询而设计的。存入HashSet的对象必须定义hashCode方法。

TreeSet采用红黑树的数据结构进行排序元素,使用它可以从Set中提取有序(升序或者降序)的序列,需要注意的是,存入自定义类是,TreeSet需要维护元素的存储顺序,因此定义类要实现Comparable接口并定义compareTo方法。

LinkedHashSet内部使用散列以加快查询速度,同时使用链表维护元素插入的次序,在使用迭代器Iterator遍历Set时,结果会按元素插入的次序显示。

Map实现类分析:

HashMap是一个最常用的Map,它根据键的hashCode值存储数据,根据键可以直接获取它的值,具有很快的访问速度。HashMap最多只允许一条记录的键为NULL,允许多条记录的值为NULL。HashMap不支持线程同步,即任一刻可以有多个线程同时写HashMap,可能会导致数据的不一致。如果需要同步,可以用Collection的SynchronizeMap方法使HashMap具有同步的能力。

Hashtable与HashMap类似,不同的是,它不允许记录的键或者值为空;它支持线程的同步,即任一时刻只有一个线程能写Hashtable,因此也导致了Hashtable在写入时会比较慢。

LinkedHashMap保持了记录的插入顺序,在用迭代器Iterator遍历LinkedHashMap时,先得到的是记录肯定是先插入的。在遍历时会比HashMap慢。

TreeMap能够把它保持的记录根据键排序,默认是按升序排序,也可以指定排序的比较器。当用Iterator遍历TreeMap是,得到的记录是排过序的。

//以上内容来自《Java JDK实例宝典》,作者:夏先波。本人上文属于学习笔记。望作者勿要介意。如有侵犯,请联系删除。


推荐阅读
  • 深入理解Kafka服务端请求队列中请求的处理
    本文深入分析了Kafka服务端请求队列中请求的处理过程,详细介绍了请求的封装和放入请求队列的过程,以及处理请求的线程池的创建和容量设置。通过场景分析、图示说明和源码分析,帮助读者更好地理解Kafka服务端的工作原理。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • Whatsthedifferencebetweento_aandto_ary?to_a和to_ary有什么区别? ... [详细]
  • Google Play推出全新的应用内评价API,帮助开发者获取更多优质用户反馈。用户每天在Google Play上发表数百万条评论,这有助于开发者了解用户喜好和改进需求。开发者可以选择在适当的时间请求用户撰写评论,以获得全面而有用的反馈。全新应用内评价功能让用户无需返回应用详情页面即可发表评论,提升用户体验。 ... [详细]
  • 开发笔记:计网局域网:NAT 是如何工作的?
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了计网-局域网:NAT是如何工作的?相关的知识,希望对你有一定的参考价值。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • flowable工作流 流程变量_信也科技工作流平台的技术实践
    1背景随着公司业务发展及内部业务流程诉求的增长,目前信息化系统不能够很好满足期望,主要体现如下:目前OA流程引擎无法满足企业特定业务流程需求,且移动端体 ... [详细]
  • 众筹商城与传统商城的区别及php众筹网站的程序源码
    本文介绍了众筹商城与传统商城的区别,包括所售产品和玩法不同以及运营方式不同。同时还提到了php众筹网站的程序源码和方维众筹的安装和环境问题。 ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • Java程序设计第4周学习总结及注释应用的开发笔记
    本文由编程笔记#小编为大家整理,主要介绍了201521123087《Java程序设计》第4周学习总结相关的知识,包括注释的应用和使用类的注释与方法的注释进行注释的方法,并在Eclipse中查看。摘要内容大约为150字,提供了一定的参考价值。 ... [详细]
  • 本文介绍了一个适用于PHP应用快速接入TRX和TRC20数字资产的开发包,该开发包支持使用自有Tron区块链节点的应用场景,也支持基于Tron官方公共API服务的轻量级部署场景。提供的功能包括生成地址、验证地址、查询余额、交易转账、查询最新区块和查询交易信息等。详细信息可参考tron-php的Github地址:https://github.com/Fenguoz/tron-php。 ... [详细]
author-avatar
O依楼观雪O
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有