---------------------- ASP.Net+Android+IO开发S、.Net培训、期待与您交流! ---------------------
一、集合概述
1、集合与数组的比较:
首先要明白数据在计算机中的存储方式,常用的有数组、链表、哈希表和二叉树等。
所有的数组都用数组这个方式存储数据,这种方式查询快,但是插入、删除慢,而且是不可变长度的(数组的扩容其实是建立一个新的数组,增加原来数组的一半或者全长,然后将老数组中的数据copy到新数组中)
而集合则比较全面了,集合里边有各种底层实现方式,比如底层为数组的ArrayList、底层为链表的LinkedList、底层为哈希表的HashSet和HashMap,还有底层为二叉树的TreeSet和TreeMap。
集合在使用的时候不用考虑长度问题,即使是底层用数组实现的ArrayList也已经在内部封装好了自动扩容的功能,而且集合还能把不同的对象装在一起。
- 集合作为容器可以分为很多种,如水杯就有很多种。
- 多种集合的共性抽取,就是集合框架: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
相关推荐
本资料包是黑马程序员提供的详细教程,涵盖了Java集合的例题、源码以及配套的PPT教学文档,旨在帮助学习者深入理解和掌握Java集合的使用。 首先,我们来探讨Java集合框架的基本概念。Java集合框架包括接口和实现类...
《黑马程序员Java面试宝典》是一本...通过《黑马程序员Java面试宝典》的学习,你可以系统地复习和掌握这些知识点,提高自己的面试竞争力。书中的问题和解答将帮助你更好地理解Java编程的本质,提升在面试中的自信心。
Java基础知识点总结 本文将对Java基础知识点进行总结,涵盖了变量、数据输入、数组、方法、封装、API、字符串、ArrayList、继承、多态等方面的重要概念。 变量和数据输入 在Java中,变量是存储数据的容器。变量的...
通过学习《黑马程序员面试宝典》,开发者不仅可以深入理解Java的核心概念和技术,还能了解企业在招聘时关注的热点问题,从而有针对性地进行复习和准备。这份资料提供的面试真题解析更是能帮助开发者模拟实战,提前...
此外,理解Java的核心概念,如类、对象、继承和多态,以及掌握常用的Java库(如集合、I/O流和多线程)和框架,对于成为一名熟练的Java开发者至关重要。 总的来说,这份课后答案文档涵盖了Java入门的各个方面,通过...
### 黑马程序员入学Java知识 #### Java概述与基础知识 1. **何为编程?** - 编程是通过特定的计算机语言来编写指令,让计算机执行一系列任务的过程。 2. **Java语言概述,历史、特点** - **概述**:Java是一种...
《黑马程序员JAVA面试宝典2018年5月最新版》是一本专门为Java开发者准备的面试指南,它集合了2018年5月时最新的面试知识点和业界趋势,旨在帮助Java程序员在求职过程中更好地应对各类技术面试。这本书可能涵盖了Java...
在"黑马程序员_Java基础辅导班教程课件[第01期]第4天"中,我们可以推测这是针对初学者的Java编程课程,旨在帮助学员掌握Java的基础知识。 在课程的第4天,可能讲解了以下核心概念: 1. **类(Class)**:`Demo.class...
《2018-2019年黑马最新版Java程序员面试宝典+题库pdf》是一份集合了近年来Java编程领域重点知识和面试常见问题的综合资源。这份资料主要针对初级Java程序员,旨在帮助他们巩固基础知识,掌握面试技巧,以便在求职...
这个复习资料主要涵盖了Eclipse的使用、程序的断点调试、Eclipse常用快捷键、JUnit测试框架、Java 5的新特性(静态导入和自动装箱拆箱)以及增强for循环和可变参数等知识点。 1. **Eclipse的使用**: Eclipse是一...
本文将为你提供一份详尽的Java基础知识概述,适合初学者和有经验的开发者作为复习材料。 1. Java基础语法 Java的基础语法是编程的基础,理解和掌握它至关重要。 1.1 注释 注释是程序员为了方便理解和维护代码而...
传智播客是知名的IT教育品牌,其“黑马程序员”系列课程在行业内享有较高的声誉,为许多初学者和进阶者提供了丰富的学习资源。 【描述】"市面最新,请各位慢用" 暗示这是一套较新的Java教学资料,涵盖了最新的技术...
为了满足学习者自我提升和评估技术的需求,黑马程序员推出了一个名为“黑马测试题集合”的资源包,它包含了丰富的测试题目,以供学习者在学习过程中进行自我检验和复习。 这个“黑马测试题集合”汇集了作者通过积分...
在Java开发的世界里,扎实的基础是每一位程序员的基石。本篇将围绕"java视频教程_黑马Java零基础辅导班[第二期]11天课件源码"这一主题,深入探讨在学习Java过程中所涉及的重要知识点,通过分析提供的课件源码,旨在...
"黑马学员基础资料大全"可能包含这些领域的详细解答和实例,提供了一个全面学习和复习Java面试知识的资源库。通过深入学习和实践这些知识点,不仅能在面试中脱颖而出,也能在实际工作中提升技术水平。
《JavaWeb程序设计任务教程(第2版)》课后答案-docx文档是一份针对该教程中课后习题的详细解答集合。该文档以Microsoft Word的.docx格式呈现,包含了教程中每一章节后的练习题及其相应的解答。 二、适用人群 学生...
通过阅读“黑马程序员入学Java知识—精华总结(下).doc”,你可以系统地复习和掌握这些知识点,为面试做好充分准备。记住,理论知识的掌握需要结合实践,通过编写代码和解决实际问题来加深理解。祝你在Java学习道路上...
【传智播客PPT】是一份集合了多种IT技术领域的教学资料,主要涵盖了Java基础、JDBC数据库操作以及SSH(Struts、Spring、Hibernate)三大框架等内容。这些PPT资源是传智播客教育机构精心制作的,旨在帮助学习者深入...
这份资料由黑马程序员精心编纂,集合了多家知名公司的面试题目,涵盖了广泛且深入的Java知识点。 首先,基础篇中,你需要熟悉Java语言的基础语法,包括但不限于数据类型(基本类型与引用类型)、运算符、流程控制...