Java第9章 集合和工具类
Java程序设计--集合的总结学习
List<String> localList = new ArrayList<String>(); localList.addAll(list); for (int i = 0; i < count; i++) { String str = localList.get(i); list.remove(str);
6 / 38
集合迭代器的工作原理
next()
返回的元素
next()
删除的元素
remove ()
Page
7 / 38
Lu Qiang, 2009 Hefei University of Technology , School of Computer and Information
List中不安全的操作
previous
data
next
Page
14 / 38
链表的编辑操作
插入
head节点 data next data next data next=null
data
next
删除
head节点 data next data next data next=null
Page
15 / 38
Lu Qiang, 2009 Hefei University of Technology , School of Computer and Information
本章学习提示
集合框架中的接口
• Collection:集合层次中的根接口,JDK没有提供这 个接口直接的实现类。 • Set:不能包含重复的元素。SortedSet是一个按照 升序排列元素的Set。 • List:是一个有序的集合,可以包含重复的元素。提 供了按索引访问的方式。 • Map:包含了key-value对。Map不能包含重复的 key。SortedMap是一个按照升序排列key的Map。
JAVA各章知识总结
Java语言是面向对象技术成功应用的典范。
诞生于1955年的Java语言在短短的几年间便席卷全球,以20世纪末网络科技和网络经济所特有的令人瞠目结舌的速度迅速发展,是21世纪开发信息系统的主流技术。
由于Java语言所具有的简洁性、纯属面向对象等特征,也使得它非常适合于在大学中面向对象程序设计的教学。
本学期我们开设了《Java语言与面向对象程序设计》这门课,通过对Java 一段时间的自学,我想在此谈谈我自己摸索学习Java的心得体会。
学习Java切忌浮躁,要注意以下几点:1.欲速则不达,初学者请不要被新技术迷惑,先把基础学扎实。
2.要扎扎实实,一步一个脚印的逐步学习,不要想着一步登天。
给自己定一个学习流程,按照流程学习。
3.多查API,它是Java编程的基本方法,也是编程过程中所不断利用的资源。
Java的学习过程不仅仅是基本语法的学习,更多的是去学习和掌握它所提供的API类库。
对于所接触到的类,方法,都去仔细去阅读文档的说明,再用自己编写的实例去比较一下。
4.看再多的书是学不全脚本的,要多实践,学习脚本最好的方法之一就是多练习;不要只看不练,一定要把书上的例子亲手敲到电脑上实践,千万不要照抄,更不要复制粘贴;看得懂代码,不代表会写代码。
学编程语言不仅仅是从理论上的学习,更重要的是要利用这门语言为你的思想服务。
理解这门语言是首要的,但是要达到心领神会、融会贯通就必须勤动手,多去时间,多编一些例子。
计算机科学是注重实践的学科,成功的软件开发人员无不经过大量的上机锻炼,只有理论和实践相结合才能真正掌握只是和技能。
5.看得懂的书,请仔细看;看不懂的书,请硬着头皮看;书读百遍,其义自现。
第一遍书看不懂就看第二遍、第三遍。
6.当你用脚本到一半却发现自己用的方法很拙劣时,请不要马上停手;请尽快将余下的部分粗略的完成以保证这个代码的完整性,然后分析自己的错误并重新编写和工作。
7.遇到问题,先自己想办法解决,查查文档,不要什么都不看就发帖子问。
集合的概念java
集合的概念java在Java中,集合是一种用于存储对象的容器。
它提供了一系列方法来操作和处理这些对象。
Java中的集合主要分为两大类:Collection和Map。
Collection是一个接口,表示一组对象的容器,它有多个实现类,如List、Set 等。
Collection接口定义了一些常用的操作方法,如添加元素、删除元素、判断元素是否存在等。
List是有序的集合,可以有重复的元素。
常见的List实现类有ArrayList和LinkedList。
Set是无序的集合,不允许有重复的元素。
常见的Set实现类有HashSet和TreeSet。
Map是存储键值对的集合,每个键都是唯一的。
常见的Map实现类有HashMap 和TreeMap。
在使用集合时,首先需要创建集合对象,然后使用add()方法添加元素,使用remove()方法删除元素,使用contains()方法判断元素是否存在等。
也可以使用迭代器(Iterator)遍历集合中的每个元素。
示例代码如下:javaimport java.util.*;public class CollectionExample {public static void main(String[] args) {创建一个List集合List<String> list = new ArrayList<>();添加元素list.add("apple");list.add("banana");list.add("orange");输出集合元素for (String element : list) {System.out.println(element);}删除元素list.remove("banana");判断元素是否存在System.out.println(list.contains("apple")); 输出trueSystem.out.println(list.contains("banana")); 输出false }}上述代码创建了一个List集合,并添加了一些元素。
java中集合的概念
java中集合的概念Java中的集合是一种非常重要的数据结构,用于存储和操作一组对象。
集合框架包含了许多类和接口,可以方便地进行数据的存储、查询、排序等操作,使得Java程序开发变得更加高效和便捷。
在本文中,我们将逐步介绍Java中集合的概念和用法。
一、集合框架概述Java中的集合框架是一个包含了多个接口和类的层次结构,用于表示和操作一组对象。
集合框架包含了通用的集合接口和实现,以及特定的集合类和接口,如List、Set、Map等。
集合框架的接口和类都是通过泛型实现的,可以存储任意类型的对象,比如基本类型和自定义类型的对象。
二、集合框架的接口Java中的集合框架包含了多个接口,其中包括:1. Collection:代表一组对象的集合,是其他集合接口的父接口。
它定义了一些通用的方法,如添加、删除、迭代等。
2. List:代表有序的集合,其中每个元素都有一个对应的索引。
List允许重复元素出现,并且可以通过索引访问、添加、删除元素。
3. Set:代表无序的集合,其中每个元素都是唯一的。
Set不允许重复的元素出现,可以用来去重。
4. Map:代表一组键值对的集合,其中每个键都是唯一的。
Map 允许多个值对应同一个键,可以用来快速查找和存储数据。
三、集合类的实现Java中的集合类可以通过实现集合接口来实现。
如ArrayList、LinkedList、HashSet、TreeSet、HashMap、TreeMap等都是集合类的实现,我们可以通过这些集合类来方便地实现对一组对象的操作。
例如:1. 使用ArrayList来实现List接口,可以进行元素的添加、删除、查询等操作:List<String> list = new ArrayList<>();list.add("Alice");list.add("Bob");System.out.println(list.get(1));2. 使用HashSet来实现Set接口,可以去重并存储元素:Set<Integer> set = new HashSet<>();set.add(1);set.add(2);set.add(2);System.out.println(set.size());3. 使用HashMap来实现Map接口,可以快速查找并存储数据:Map<String, Integer> hashMap = new HashMap<>(); hashMap.put("Alice", 12);hashMap.put("Bob", 18);System.out.println(hashMap.get("Bob"));四、集合的迭代Java中的集合类都实现了Iterable接口,因此可以使用迭代器来访问集合中的元素。
java集合类基础问题汇总
java集合类基础问题汇总1、Java集合类框架的基本接⼝有哪些?参考答案集合类接⼝指定了⼀组叫做元素的对象。
集合类接⼝的每⼀种具体的实现类都可以选择以它⾃⼰的⽅式对元素进⾏保存和排序。
有的集合类允许重复的键,有些不允许。
Java集合类提供了⼀套设计良好的⽀持对⼀组对象进⾏操作的接⼝和类。
Java集合类⾥⾯最基本的接⼝有:Collection:代表⼀组对象,每⼀个对象都是它的⼦元素。
Set:不包含重复元素的Collection。
List:有顺序的collection,并且可以包含重复元素。
Map:可以把键(key)映射到值(value)的对象,键不能重复。
2、为什么集合类没有实现Cloneable和Serializable接⼝?参考答案克隆(cloning)或者是序列化(serialization)的语义和含义是跟具体的实现相关的。
因此,应该由集合类的具体实现来决定如何被克隆或者是序列化。
3、什么是迭代器(Iterator)?参考答案Iterator接⼝提供了很多对集合元素进⾏迭代的⽅法。
每⼀个集合类都包含了可以返回迭代器实例的迭代⽅法。
迭代器可以在迭代的过程中删除底层集合的元素,但是不可以直接调⽤集合的remove(Object Obj)删除,可以通过迭代器的remove()⽅法删除。
4、Iterator和ListIterator的区别是什么?参考答案下⾯列出了他们的区别:Iterator可⽤来遍历Set和List集合,但是ListIterator只能⽤来遍历List。
Iterator对集合只能是前向遍历,ListIterator既可以前向也可以后向。
ListIterator实现了Iterator接⼝,并包含其他的功能,⽐如:增加元素,替换元素,获取前⼀个和后⼀个元素的索引,等等。
5、快速失败(fail-fast)和安全失败(fail-safe)的区别是什么?参考答案Iterator的安全失败是基于对底层集合做拷贝,因此,它不受源集合上修改的影响。
java集合的定义
java集合的定义1. Java集合是一种用于存储和操作一组对象的数据结构。
它提供了一种更高级别的抽象,可以方便地进行添加、删除、查找和遍历操作。
集合可以存储多个对象,并且可以根据需要动态调整大小。
2. Java集合框架是Java编程语言提供的一组接口、类和算法,用于实现各种集合类型。
它包括了List、Set、Queue和Map等常用集合接口,以及它们的具体实现类。
集合框架提供了一种标准化的方式来处理集合,使得开发人员可以更加方便地使用和操作集合。
3. Java集合框架中的每个集合都是通过特定的接口来定义的。
例如,List接口代表了一个有序的集合,可以包含重复的元素。
Set接口代表了一个无序的集合,不允许包含重复的元素。
Queue接口代表了一个先进先出的队列,可以用于实现任务调度和事件处理等场景。
Map接口代表了一组键值对的映射,可以通过键来查找对应的值。
4. 在集合框架中,每个具体的集合类都实现了相应的接口,并提供了一套通用的方法来操作集合。
例如,ArrayList是List接口的一个实现类,它使用数组来存储元素,并提供了一系列方法来添加、删除、查找和遍历列表中的元素。
HashSet是Set接口的一个实现类,它使用哈希表来存储元素,并提供了一套方法来添加、删除和查找集合中的元素。
5. Java集合框架还提供了一些算法和工具类,可以用于对集合进行排序、查找和操作等操作。
例如,Collections类提供了一系列静态方法,可以对集合进行排序、查找和复制等操作。
Arrays类提供了一系列静态方法,可以对数组进行排序、查找和复制等操作。
这些算法和工具类可以大大简化集合的处理过程,并提高开发效率。
总结:Java集合是一种用于存储和操作一组对象的数据结构,它提供了一种更高级别的抽象,可以方便地进行添加、删除、查找和遍历操作。
Java集合框架是Java编程语言提供的一组接口、类和算法,用于实现各种集合类型,并提供了一种标准化的方式来处理集合。
java集合
比较指定的对象与列表是否相等。 E get(int index)
返回列表中指定位置的元素。
int indexOf(Object o)
返回列表中首次出现指定元素的索引,如果列表不包含此 元素,则返回 -1。
Iterator iterator()
<E>
返回以正确顺序在列表的元素上进行迭代的迭代器。
int lastIndexOf(Object o)
List接口和LinkedList类 3-3
• 第二步:具体实现
public clas1s、Fir添stL加eve头lTit条leD、B3以{ 及最末条新闻标题 public static void main(String[] args) { FirstL2ev、elT获itle取car头= n条ew、Fir以stL及eve最lTit末le(1条, "汽新车闻", "标管理题员", new Date()); FirstLevelTitle medical = new FirstLevelTitle(2, "医学", "管理员",new Date()); 3、删除头条、以及最末条新闻标题
iterator() 返回在此 collection 的元素上进行迭代的迭代器。
remove(Object o) 从此 collection 中移除指定元素的单个实例,如果存在的话(可选操
作)。 size()
返回此 collection 中的元素数。 toArray()
返回包含此 collection 中所有元素的数组。
返回列表中最后出现指定元素的索引,如果列表不包含此 元素,则返回 -1。
List常用方法
java中集合知识点总结
java中集合知识点总结1. Collection接口Collection接口是Java中集合类的基本接口,它定义了一组通用的操作方法,包括添加、删除、查找等操作。
Collection接口有三个主要的子接口:List、Set和Queue。
(1) ListList是一种有序的集合,它允许重复的元素,并且可以按照索引访问元素。
List接口中有常用的实现类:ArrayList、LinkedList和Vector。
其中,ArrayList是基于数组实现的,它支持快速的随机访问和插入操作;LinkedList是基于双向链表实现的,它支持快速的插入和删除操作;Vector是线程安全的类,它支持并发访问。
(2) SetSet是一种不允许重复元素的集合,它用来存储唯一的元素。
Set接口中有常用的实现类:HashSet、LinkedHashSet和TreeSet。
其中,HashSet是基于哈希表实现的,它提供了快速的查找和插入操作;LinkedHashSet是基于哈希表和链表实现的,它保持了元素的插入顺序;TreeSet是基于红黑树实现的,它提供了有序的集合。
(3) QueueQueue是一种先进先出的集合,它用来存储元素,并且支持插入和删除操作。
Queue接口中有常用的实现类:LinkedList和PriorityQueue。
其中,LinkedList可以作为Queue来使用,它支持快速的插入和删除操作;PriorityQueue是基于堆实现的,它提供了优先级队列的功能。
2. Map接口Map接口是Java中的映射表,它用来存储键值对的数据。
Map接口中有常用的实现类:HashMap、LinkedHashMap、TreeMap和Hashtable。
其中,HashMap是基于哈希表实现的,它提供了快速的查找和插入操作;LinkedHashMap是基于哈希表和链表实现的,它保持了键值对的插入顺序;TreeMap是基于红黑树实现的,它提供了有序的映射表;Hashtable是线程安全的类,它支持并发访问。
面向对象程序设计-第九章-实用工具类
1.Wrapper类
为了支持以面向对象的方式处理简单数据类型,Java 为每一种基本数据类型提供了Wrapper类。
基本数据类型
Wrapper类
boolean
Boolean
byte
Byte
char
Character
short
Short
int
Integer
long
Long
float
Float
double
13
3.继承性
2.LinkedList
LinkedList类等同于数据结构中的链表的概念。链表
通常是用来存放一个群有顺序但个数经常变动的组件,
它的长度可以由内容自动调整大小。它是接口是List。
◆LinkedList类的写法:
例:List list = new LinkedList();
LinkedList ll = new LinkedList();
System.out.println(Math.PI); //2.718281828459045 System.out.println(Math.E); //3.14159653589793
10
ng.Math
◆Math类的方法还包涵了数学函数,有三角函数、对数、
求幂等。 例: int abs(int i); //绝对值
11
3.容器类
Java把可以存储和操作对象的集合的类称为容器类。 在Java中已经有一个可以存储对象,那就是数组。数组 的长度是不可以变的,只能存放同一个类型的对象。
容器类特点一共有三点: ◆框架是高性能的,对基本类集的实现是高效率的。 一般人很少去改动这些已经很成熟并且高效的API。 ◆容器类允许不同类型的容器以相同的方式和高度 互操作方式工作。 ◆容器类容易扩展和修改。
java中的常用集合类整理
java中的常⽤集合类整理⽬录Collection接⼝集合的遍历:iterator 接⼝集合的遍历:增强for循环List接⼝ArrayListSet接⼝Map接⼝HashMapLinkedHashMapTreeMapPropertiesCollections⼯具类总结集合、数组都是对多个数据进⾏存储操作(主要是内存层⾯存储)的结构,简称Java容器。
数组的特点1.数组初始化以后,长度确定不可变2.数组定义好,其元素的类型确定不可变(可能有多态性)3.数组中提供的⽅法有限,对于添加、删除、插⼊数据等操作不⽅便。
4.获取数组中实际元素的个数是没有办法的。
5.数组存储数据的特点是有序、可重复的。
Java集合可分为Collection和Map两种体系,集合存储的优点是解决数组存储数据⽅⾯的弊端。
Collection接⼝:单列数据,⽤来存储⼀个⼀个的对象List接⼝:元素有序,可重复的集合 --> '动态'数组Set接⼝ :元素⽆序、不可重复的集合Map接⼝:双列数据,保存有映射关系(键值对)的集合Collection接⼝向collection接⼝的实现类的对象中添加数据obj时,要求obj所在类要重写equals⽅法。
Abstract Methodsadd(Object e):将元素e添加到集合中size():获取添加的元素个数addAll(Collection coll):将形参coll集合的元素添加到当前集合中clear():清空集合元素,集合仍然存在,只是集合⾥没有元素isEmpty():判断当前集合是否为空contains(Object obj):判断当前集合中是否包含obj,是否包含是通过调⽤obj的equals判断containsAll(Collection coll):判断形参coll中的所有元素是否都存在当前集合中。
remove(Object obj):移除某个元素,同样通过equals寻找移除的元素removeAll(Collection coll):从当前集合中移除coll集合中所有的元素,需要调⽤equals函数retainAll(Collection coll):求两个集合的交集,结果为修改当前集合后的集合。
java常用集合使用方法
java常⽤集合使⽤⽅法1.初步尝试java中的集合使⽤⽅式:public static void main( String [] args ){//List 对象User user=User.builder().id(0).name("huhua"+0).build();//a.最常见Add的初始化⽅式List<User> users=new ArrayList<User>();for (int i=0;i<100;i++){users.add(User.builder().id(i).name("huhua"+i).build());}//b.使⽤双花括号在初始化的同时赋值List<User> users2= new ArrayList<User>() {//这个⼤括号就相当于我们 new 接⼝{//这个⼤括号就是构造代码块会在构造函数前调⽤this.add(new User(0,"huahua0"));this.add(new User(1,"huahua1"));}};//c.利⽤Lists⼯具类 https:///google-guava///c1. Lists 提供了两个⽅法:⼀个是创建⼀个空列表;。
List<String> list1 = Lists.newArrayList();list1.add("str1");list1.add("str2");list1.add("str3");//c2.⼀个是创建空列表的同时遍历迭代器,将它的值添加到列表中List<String> list2 = Lists.newArrayList(list1.iterator());//d. 利⽤Arrays⼯具类List<String> arrList= Arrays.asList( new String[]{"huahu0","huahau1","huahua2"});//e.Collections 还提供了⼀个为 List ⼀次性添加所有元素的⽅法,弥补了原先 List 只能添加 Collections,⽽不⽀持数组的缺憾。
JAVA各种计算工具类
JAVA各种计算工具类Java是一种面向对象的编程语言,它提供了丰富的类库和工具来实现各种计算任务。
在以下内容中,我将介绍一些常用的Java计算工具类。
1. Math类:这是Java中提供基本数学运算的工具类。
它包含的方法可以进行基本的运算,如加减乘除、取整、取余等。
此外,Math类还提供了一些常用的数学函数,如指数函数、对数函数、三角函数等。
2. BigDecimal类:在Java中,浮点数的精度是有限的,可能会导致精度丢失的问题。
为了解决这个问题,可以使用BigDecimal类进行高精度计算。
BigDecimal类提供了方法来执行加减乘除等基本运算,同时具有设置精度和舍入模式的功能。
3. Random类:这个类提供了生成伪随机数的方法。
可以使用Random类来生成随机的整数、浮点数或布尔值。
另外,Random类还可以生成符合特定分布的随机数。
4. BitSet类:BitSet类用于处理位数据,它提供了一组方法来操作位集合。
使用BitSet类可以进行位运算,如位与、位或、位异或等。
此外,BitSet类还提供了方法来进行位集合的操作,如设置位、清除位、翻转位等。
5. Calendar类:这个类用于处理日期和时间。
Calendar类提供了一组方法来获取日期和时间的各个部分,如年、月、日、时、分、秒等。
它还提供了一组方法来进行日期和时间的计算和格式化。
6. Arrays类:这个类用于处理数组。
Arrays类提供了一组方法来对数组进行排序、查找、比较等操作。
它还提供了方法来生成数组的字符串表示。
9. BigInteger类:与BigDecimal类类似,BigInteger类用于处理大整数运算。
它提供了一组方法来进行基本运算,如加减乘除、取模等。
BigInteger类还提供了方法来处理特定的整数操作,如计算阶乘、计算幂等。
10. DecimalFormat类:这个类用于格式化数值。
DecimalFormat类提供了一组方法来控制数值的格式,如设置小数位数、设置千位分隔符、设置正负号等。
java集合知识点总结
java集合知识点总结Java集合是Java编程中的一个重要的部分,它的理解和使用对编程者来说是必不可少的。
它为开发者提供了一种更好地操作和管理数据的方法,大大提高了应用开发所需的效率。
本文将简要介绍Java 集合的相关概念与特性,并通过实例来更好地了解其中的知识点。
一、Java集合介绍Java集合(Collection)包括一组对象(Object),它们可以是基本类型、对象或数组,它们可以用来存储,操作和管理程序中的数据,充分体现了“面向对象”编程的抽象能力。
Java集合的特点有:(1)集合是一种容器,可以存放任何类型的对象,它是一种非常抽象的概念,可以把一堆数据项放入集合对象中;(2)集合可以自动管理里面存放的对象,提供了统一的接口来访问和修改集合中的对象,从而避免了繁琐的操作;(3)集合的每个元素都有一定的顺序,也就是说可以通过顺序来访问它们;(4)集合还可以通过索引来访问元素,而且允许程序在集合中搜索元素,这对于快速定位某个元素是非常有用的;(5)集合可以保持对象的顺序,新加入的对象总是会在特定的位置被存放,从而保证了集合中元素的顺序;(6)集合可以保持在一个容器中的唯一性,允许只有一个唯一的元素存在,因此可以用来实现不出现重复元素的数据结构。
二、Java集合类Java集合类提供了一系列容器来存储、操作和管理不同类型的数据。
基本上,Java提供的集合类可以分为两个基本类型:集合和映射。
集合:集合是用来存储元素的一种容器,它提供了一系列的方法,可以用来添加、移除和检索容器中的对象。
在Java中,拥有两个基本的集合类型:线性集合和非线性集合。
线性集合:线性集合是指那些元素之间存在有序关系的集合,元素在线性集合中可以通过索引来访问。
它主要包括List和Set,其中List是有序的集合,而Set则是无序的集合。
非线性集合:非线性集合是指元素之间没有有序关系的集合,它提供的操作更为灵活,可以通过指定的键来访问元素。
java集合总结
java集合总结一、数组、集合数组、集合:都是一种容器,用一个对象管理多个对象;数组:不能自动增长;只能存放同类型的元素集合:能自动扩容;部分集合允许存放不同类型的元素;二、学习这些集合类要把握哪些东西:1〕怎样得到〔选择〕集合对象;2〕怎样添加元素3〕怎样删除元素4〕怎样循环遍历没一个元素三、list、set、mapcollection:父接口;Set:接口一个实现类:HashSetList:接口三个实现类:LinkedList,Vector,ArrayListSortedSet:接口实现类:TreeSet1、List:List:有序列表,允许存放重复的元素;实现类:ArrayList:数组实现,查询快,增删慢,线程担心全,轻量级;下标也是从0开头;LinkedList:链表实现,增删快,查询慢Vector:数组实现,线程平安,重量级2.Set:无序集合,不允许存放重复的元素;实现类HashSet:equals返回true,hashCode返回相同的整数;哈希表;子接口SortedSet:对Set排序实现类:TreeSet:二叉树实现的;看API:E泛型:表示一个对象;Iterator:接口,迭代器;java.util;hasNext();next();remove();Iterable:可迭代的,访问的;ng;实现了可迭代的接口就可以用迭代的方式访问;只需实现iterator();方法即可;Iteratoriterator();三种循环的访问方式:只有实现了Iterable接口的才能用第三种;能用其次种的也肯定能用第三种;ArrayList:自动扩容,是数组照搬过来的;3.MapHashMap:键值对,key不能重复,但是value可以重复;key 的实现就是HashSet;value对应着放;HashSet的后台有一个HashMap;初始化后台容量;只不过生成一个HashSet的话,系统只供应key的访问;假如有两个Key重复,那么会掩盖之前的;Hashtable:线程平安的Properties:java.util.Properties;key和value都是String 类型,用来读配置文件;HashMap与Hashtable区分:HashMap线程担心全的,允许null作为key或value;Hashtable线程平安的,不允许null作为key或value;TreeMap:对key排好序的Map;key就是TreeSet,value对应每个key;key要实现Comparable接口或TreeMap有自己的构造器;HashSet:remove(Objecto)的原则看这个对象O的Hashcode和equals是否相等,并不是看是不是一个对象;定义一个Map;key是课程名称,value是Integer表示选课人数;map.put(cou,map.get(cou)+newInteger(1));四、Hashtable、Properties1,Hashtable:实现了Map接口,此类实现一个哈希表,作用和HashMap相同。
Java程序设计课件:泛型与集合
List的常用方法
方法名 add(int index, E element) addAll(int index, Collection<?
extends E> c) get(int index)
indexOf(Object o)
lastIndexOf(Object o)
程序员使用集合框架提供的接口和类,在具体应 用时,不必考虑这些数据结构算法的实现细节, 只需用这些类创建对象并直接应用即可,这大大 提高了编程效率。
2023/12/28
8/35
6.2.1集合框架
核心接口主要有Collection、List、Set、 Queue、Deque和Map。
Collection
方法名 add(E e) clear() equals(Object o) isEmpty() size() iterator() hashCode() toArray() removeAll(Collection<?> c) retainAll(Collection<?> c) contains(Object o) remove(Object o) containsAll(Collection<?> c)
将集合 c中的所有元素添加到当前集合中,添加成功 返回true。
11/35 2023/12/28
Set 接口
Set接口用来描述数据结构中的集合。它具有 与 Collection 完全一样的接口,只是Set 不 保存重复的元素,向Set添加元素时,不保证 元素添加后与添加的顺序一致。实现它的常 用子类有TreeSet类和HashSet类。
remove(int index) set(int index, E element) listIterator()
如何使用Java中集合类的详细讲解
import java.util.*;public class Testset {public static void main(String args[]){ Set set = new HashSet();set.add("aaa");set.add("bbb");set.add("aaa");set.add("bbb");set.add("aaa");set.add("bbb");set.add("aaa");set.add("bbb");set.add("aaa");set.add("bbb");Iterator ite=set.iterator();set.size();while(ite.hasNext())System.out.println("------"+ite.next()); }}在使用Java的时候,我们都会遇到使用集合(Collection)的时候,但是Java API提供了多种集合的实现,我在使用和面试的时候频频遇到这样的“抉择” 。
:)(主要还是面试的时候)久而久之,也就有了一点点的心得体会,写出来以供大家讨论。
总的说来,Java API中所用的集合类,都是实现了Collection接口,他的一个类继承结构如下:Collection<--List<--VectorCollection<--List<--ArrayListCollection<--List<--LinkedListCollection<--Set<--HashSetCollection<--Set<--HashSet<--LinkedHashSetCollection<--Set<--SortedSet<--TreeSetVector : 基于Array的List,其实就是封装了Array所不具备的一些功能方便我们使用,它不可能走入Array的限制。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
-5-
9.1.2 集合继承层次
-6-
9.2 Collection接口下的继承者
9.2.1 Collection接口 9.2.2 Set接口 9.2.3 HashSet和TreeSet 9.2.4 List接口 9.2.5 ArrayList和LinkedList
-12-
9.2.5 ArrayList和LinkedList
ArrayList是最常用的结构,可以存储几乎任 何类型的元素,实现了List接口,并直接继 承AbstractList类。
LinkedList是另一种和ArrayList不同数据结构 的集合,该结构对集合元素进行删除和插 入操作的性能优于ArrayList。
-9-
9.2.3 HashSet和TreeSet
-10-
9.2.3 HashSet和TreeSet
-11-
9.2.4 字符类型和布尔类型
List在util包下,继承了Collection接口,允许 存放重复项,是集合日常开发中最常用到 的接口。它使用灵活,可以增加、移除元 素,也可以根据索引访问指定元素。它有 10个实现类,常用的是ArrayList和LinkedList
-28-
习题
2.编程题 1)从控制台中输入3个学生的姓名,并保存到 ArrayList集合中。然后,查找该集合中是否包含名 字为“张三”的学生,如果有,则输出“该学生在 集合中!”, 否则输出“该学生不在集合中!”。 2)在控制台中分别输入学生的学号和姓名,并保存 到HashMap<Integer,String>泛型集合中。然后,将 学号是“1”的学生姓名输出。
-29-
器返回的最后一个元素。
-14-
9.4 集合工具类Collections
-15-
9.5 Map接口
9.5.1 Map接口 9.5.2 HashMap和TreeMap
-16-
9.5.1 Map接口
Map接口提供了以“键(Key)/值(Value)”映 射关系存储数据的方式。其中每个键最多映射一 个值,同时Key不允许重复,Value允许重复且无 序。该接口常用实现类有HashTable、HashMap、 TreeMap等。
-7-
9.2.1 Collection接口
-8-
9.2.2 Set接口
Set接口继承自Collection,同时加入额外的 内容。该接口要求不包含重复元素,最多 允许一个NULL元素。
实现Set接口的抽象类是AbstractSet,它继 承自AbstractCollection,作用是提供接口主 要部分的实现,以此来减少其他类实现该 接口时的工作量。AbstractSet抽象类没有重 写父类的方法,但增加了equals和hashCode 的实现。
TreeMap是一个有序集合,是红黑树的实现 ,可以查找记录。
-18-
9.6 泛型集合
集合存储数据时,会把数据自动转为 Object类型存入,然后在取出时会把它 再强制转换成原数据类型。当存入时 的数据类型和准备转换成的数据类型 不兼容时,则会报“类转换异常”。 为了减少这种情况发生,Java从JDK1.5 开始支持“泛型”。“泛型”就是在 定义方法参数、成员变量、集合等隐 性用到数据类型的地方,为其指明允 许存放的数据类型。
9.1 标识符和关键字
9.1.1 集合与数组的比较 9.1.2 集合继承层次
-4-
9.1.1 集合数组的比较
数组和集合的区别,包括如下3方面。 (1)数组大小固定,集合动态变化。 (2)数组效率比较高,只存储原生数据类型
;集合效率稍低,可以存储引用类型。 (3)除了泛型集合外,集合可以放多种数据
-17-
9.5.2 HashMap和TreeMap
HashMap存储和查找的速度优于其他类型的集合 。存储的数据无序,储值需要保证两部分。一个 是K(Key),是键值;另一个是V(Value),是 记录值。这两个值是成对出现的(也称为映射关 系),即计算key的散列码,并将value存储到该位 置。
-13-
9.3 集合访问类的Iterator接口
集合中专门提供了一个遍历集合元素的工 具,即迭代器Iterator。迭代器Iterator共包 含如下3个方法。
hasNext():返回布尔类型。用来检测下面 是否有元素可以迭代,如果有则返回true。
next():返回迭代的下一个元素。 remove():从迭代器指向的集合中移除迭代
第9章 集合和工具类
内容简介
9.1 集合概述 9.2 Collection接口下的继承者 9.3 集合访问器Iterator接口 9.4 集合工具类Collections 9.5 Map接口
-2-
内容简介
9.6 泛型集合 9.7 常用工具类 9.8 综合实例
-3-
-24-
9.7.4 实例演练一
使用Math方法对随机产生的小数取整
-25-
9.7.5 实例演练二
根据给定的时间,计算N小时后的时间
-26-
9.8 综合实例
查找集合中符合要求的元素并组成新集合
-27-
习题
1.填空题 1)数组的特点是________________________。 2)集合的特点是________________________。 3)集合中元素不能重复的是__________________。
-19-
9.7 常用工具类(续)
9.7.1 Java API文档 9.7.2 Math类 9.7.3 日期处理 9.7.4 实例演练1 9.7.5 实例演练2
-20-
9.7.1 Java API文档
-21-
9.7.2 Math类
-22-Biblioteka 9.7.3 日期处理-23-
9.7.3 日期处理