`

黑马程序员--java基础复习--集合

 
阅读更多

---------------------- ASP.Net+Android+IO开发S.Net培训、期待与您交流! ---------------------

一、集合概述

   1、集合与数组的比较:

   首先要明白数据在计算机中的存储方式,常用的有数组、链表、哈希表和二叉树等。

   所有的数组都用数组这个方式存储数据,这种方式查询快,但是插入、删除慢,而且是不可变长度的(数组的扩容其实是建立一个新的数组,增加原来数组的一半或者全长,然后将老数组中的数据copy到新数组中)

   而集合则比较全面了,集合里边有各种底层实现方式,比如底层为数组的ArrayList、底层为链表的LinkedList、底层为哈希表的HashSet和HashMap,还有底层为二叉树的TreeSet和TreeMap。

   集合在使用的时候不用考虑长度问题,即使是底层用数组实现的ArrayList也已经在内部封装好了自动扩容的功能,而且集合还能把不同的对象装在一起。

  

   2、集合的特点
  • 集合作为容器可以分为很多种,如水杯就有很多种。
    • 多种集合的共性抽取,就是集合框架:Collection。 抽取的不一定能创建对象,所以需要参阅顶层创建子类对象。
    • 集合中元素取出方式:迭代器、遍历、for循环、按角标索引 、枚举

   3、集合框架

 

 其中list是存入取出有序的(按角标),允许有重复元素

set是存入无序,不允许有重复元素,其实取出是有序的(HashSet按哈希值来取出,TreeSet按比较顺序来取出)

集合共性方法:

  • 1.add方法: add方法的参数类型是Object,以便于接受任意类型对象。
  • 2.集合中存储的都是对象中的引用(地址)。
    • 栈里存放集合和数据对象的引用,堆中存放集合对象(包含数据对象的引用)、数据对象。
  • 3.删除元素。
    • remove("java02");//删除java02这个元素。
    • clear(); //清空
  • 4.判断元素
    • al.contains("java02");//java02是否存在。
    • al.isEmpty();//al是否为空。
  • 5.取交集retainAll
    • al1.tetainAll(al2);//取交集,没交集为空。

二、怎么使用集合

   集合除了共性的增删改查方法外,还有一个共性的itrator方法,而且对于单列集合还可以使用collections的enumeration方法来获得对应的枚举迭代器,所以遍历集合的方法时非常多的。

   用Iterator遍历集合时,只能用Iterator的方法来操作集合,不能用集合的方法来操作集合,因为会出现并发访问集合的安全问题,而Iterator中只有一个remove方法能对集合中的元素进行操作。

   在ArrayList和LinkedList中还可以用ListIterator来遍历集合,这时候就可以有更多的操作了,比方说添加、修改等等。

   在Map集合中,遍历就麻烦一点,有两种方法:keySet和entrySet,keySet是先拿到键的集合,再遍历键的集合时根据键找值,而entrySet则是直接遍历键值对。

 

三、各种集合使用需要注意的问题

  当我们选定一个集合来使用的时候,必须要知道为什么使用这个集合,然后使用这个集合能达到什么效果,达到这个效果要符合什么条件。下面我一一列出来

  ArrayList和LinkedList:就当数组用,记住ArrayList的查询快、删除添加慢,LinkedList增删的效率比ArrayList高。

  HashSet和HashMap: 这两种集合装的对象必须重写hashCode和equals方法,因为他们的底层就是先通过hashCode来比较是不是相同事物,如果hashCode相同,再用equals比较是否相同。

  TreeSet和TreeMap:这两种集合装的对象必须实现了comparable接口或者在创建集合的时候指定了比较器,因为这些集合只通过比compareTo(实现comparable接口)或者compare(用比较器)的返回值来判断事物是否相等。

 

四、集合面试题

转自http://blog.csdn.net/bingzhen66/article/details/8081063

 

 

---------------------- ASP.Net+Android+IOS开发.Net培训、期待与您交流! ----------------------

详细请查看:http://edu.csdn.net

  • 大小: 186.3 KB
分享到:
评论

相关推荐

    Java-集合的例题 & 例题源码 & PPT教学文档(黑马程序员详细版).rar

    本资料包是黑马程序员提供的详细教程,涵盖了Java集合的例题、源码以及配套的PPT教学文档,旨在帮助学习者深入理解和掌握Java集合的使用。 首先,我们来探讨Java集合框架的基本概念。Java集合框架包括接口和实现类...

    黑马程序员java面试宝典 完整版PDF.rar

    《黑马程序员Java面试宝典》是一本...通过《黑马程序员Java面试宝典》的学习,你可以系统地复习和掌握这些知识点,提高自己的面试竞争力。书中的问题和解答将帮助你更好地理解Java编程的本质,提升在面试中的自信心。

    黑马程序员笔记自己复习Java

    Java基础知识点总结 本文将对Java基础知识点进行总结,涵盖了变量、数据输入、数组、方法、封装、API、字符串、ArrayList、继承、多态等方面的重要概念。 变量和数据输入 在Java中,变量是存储数据的容器。变量的...

    黑马程序员面试宝典(java).7z

    通过学习《黑马程序员面试宝典》,开发者不仅可以深入理解Java的核心概念和技术,还能了解企业在招聘时关注的热点问题,从而有针对性地进行复习和准备。这份资料提供的面试真题解析更是能帮助开发者模拟实战,提前...

    《Java基础入门(第3版)》(Java):课后答案-docx文档

    此外,理解Java的核心概念,如类、对象、继承和多态,以及掌握常用的Java库(如集合、I/O流和多线程)和框架,对于成为一名熟练的Java开发者至关重要。 总的来说,这份课后答案文档涵盖了Java入门的各个方面,通过...

    黑马程序员入学Java知识

    ### 黑马程序员入学Java知识 #### Java概述与基础知识 1. **何为编程?** - 编程是通过特定的计算机语言来编写指令,让计算机执行一系列任务的过程。 2. **Java语言概述,历史、特点** - **概述**:Java是一种...

    黑马程序员JAVA面试宝典2018年5月最新版

    《黑马程序员JAVA面试宝典2018年5月最新版》是一本专门为Java开发者准备的面试指南,它集合了2018年5月时最新的面试知识点和业界趋势,旨在帮助Java程序员在求职过程中更好地应对各类技术面试。这本书可能涵盖了Java...

    黑马程序员_Java基础辅导班教程课件[第01期]第4天

    在"黑马程序员_Java基础辅导班教程课件[第01期]第4天"中,我们可以推测这是针对初学者的Java编程课程,旨在帮助学员掌握Java的基础知识。 在课程的第4天,可能讲解了以下核心概念: 1. **类(Class)**:`Demo.class...

    2018-2019年黑马最新版Java程序员面试宝典+题库pdf

    《2018-2019年黑马最新版Java程序员面试宝典+题库pdf》是一份集合了近年来Java编程领域重点知识和面试常见问题的综合资源。这份资料主要针对初级Java程序员,旨在帮助他们巩固基础知识,掌握面试技巧,以便在求职...

    javaweb复习资料,黑马程序员视频

    这个复习资料主要涵盖了Eclipse的使用、程序的断点调试、Eclipse常用快捷键、JUnit测试框架、Java 5的新特性(静态导入和自动装箱拆箱)以及增强for循环和可变参数等知识点。 1. **Eclipse的使用**: Eclipse是一...

    java黑马基础资料+本人自己整理笔记+哔哩哔哩+java入行者 和 复习者可以观看第一次发作品 请多多提建议

    本文将为你提供一份详尽的Java基础知识概述,适合初学者和有经验的开发者作为复习材料。 1. Java基础语法 Java的基础语法是编程的基础,理解和掌握它至关重要。 1.1 注释 注释是程序员为了方便理解和维护代码而...

    传智播客-黑马32期Java视频

    传智播客是知名的IT教育品牌,其“黑马程序员”系列课程在行业内享有较高的声誉,为许多初学者和进阶者提供了丰富的学习资源。 【描述】"市面最新,请各位慢用" 暗示这是一套较新的Java教学资料,涵盖了最新的技术...

    黑马测试题集合

    为了满足学习者自我提升和评估技术的需求,黑马程序员推出了一个名为“黑马测试题集合”的资源包,它包含了丰富的测试题目,以供学习者在学习过程中进行自我检验和复习。 这个“黑马测试题集合”汇集了作者通过积分...

    java视频教程_黑马Java零基础辅导班[第二期]11天课件源码

    在Java开发的世界里,扎实的基础是每一位程序员的基石。本篇将围绕"java视频教程_黑马Java零基础辅导班[第二期]11天课件源码"这一主题,深入探讨在学习Java过程中所涉及的重要知识点,通过分析提供的课件源码,旨在...

    黑马java面试题总结

    "黑马学员基础资料大全"可能包含这些领域的详细解答和实例,提供了一个全面学习和复习Java面试知识的资源库。通过深入学习和实践这些知识点,不仅能在面试中脱颖而出,也能在实际工作中提升技术水平。

    《JavaWeb程序设计任务教程(第2版)》(Java):课后答案-docx文档

    《JavaWeb程序设计任务教程(第2版)》课后答案-docx文档是一份针对该教程中课后习题的详细解答集合。该文档以Microsoft Word的.docx格式呈现,包含了教程中每一章节后的练习题及其相应的解答。 二、适用人群 学生...

    黑马入学Java知识—精华总结(下)

    通过阅读“黑马程序员入学Java知识—精华总结(下).doc”,你可以系统地复习和掌握这些知识点,为面试做好充分准备。记住,理论知识的掌握需要结合实践,通过编写代码和解决实际问题来加深理解。祝你在Java学习道路上...

    传智播客PPT

    【传智播客PPT】是一份集合了多种IT技术领域的教学资料,主要涵盖了Java基础、JDBC数据库操作以及SSH(Struts、Spring、Hibernate)三大框架等内容。这些PPT资源是传智播客教育机构精心制作的,旨在帮助学习者深入...

    Java面试宝典2018-最全面试资料

    这份资料由黑马程序员精心编纂,集合了多家知名公司的面试题目,涵盖了广泛且深入的Java知识点。 首先,基础篇中,你需要熟悉Java语言的基础语法,包括但不限于数据类型(基本类型与引用类型)、运算符、流程控制...

Global site tag (gtag.js) - Google Analytics