Java常用集合类详解

实现类:

ArrayList  实现一个数组,它的规模可变并且能像链表一样被访问。它提供的功能类似Vector类但不同步,它是以Array方式实现的List,允许快速随机存取

LinkedList实现一个链表,提供最佳顺序存取,适合插入和移除元素。由这个类定义的链表也可以像栈或队列一样被使用。提供最佳顺序存取适合插入和移除元素

2)、集 Set接口(继承于Collection接口)及其实现类

特点:集合中的元素不按特定方式排序,只是简单的把对象加入集合中,就像往口袋里放东西。

对Set中成员的访问和操作是通过Set中对象的引用进行的,所以集中不能有重复对象

Set也有多种变体,可以实现排序等功能,如TreeSet,它把对象添加到集中的操作将变为按照某种比较规则将其插入到有序的对象序列中。            它实现的是SortedSet接口,也就是加入了对象比较的方法。通过对集中的对象迭代,我们可以得到一个升序的对象集合。

实现类:

HashSet 能够快速定位一个元素,要注意的是:存入HashSet中的对象必须实现HashCode()方法

TreeSet 将放入其中的元素按序存放

3)、映射 Map接口及其实现类

Map是一个单独的接口,不继承于Collection。Map是一种把键对象和值对象进行关联的容器。

特点:key不允许重复

映射与集或列表有明显区别,映射中每个项都是成对的,Map是把键对象和值对象进行关联的容器。映射中存储的每个对象都有一个相关的关键字(Key)对象,关键字决定了对象在映射中的存储位置,检索对象时必须提供相应的关键字,就像在字典中查单词一样。关键字应该是唯一的,也就是说Map中的键对象不允许重复,这是为了保证查询结果的一致性。

关键字本身并不能决定对象的存储位置,它需要对过一种散列(hashing)技术来处理,产生一个被称作散列码(hash code)的整数值,散列码通常用作一个偏置量,该偏置量是相对于分配给映射的内存区域起始位置的,由此确定关键字/对象对的存储位置。理想情况下,散列处理应该产生给定范围内均匀分布的值,而且每个关键字应得到不同的散列码。

实现类:

HashMap 实现一个键到值映射的哈希表,通过键取得值对象,没有顺序,通过get(key)来获取value,允许存储空对象,而且允许键是空(由于键必须是唯一的,当然只能有一个);

HashTable 实现一个映象,所有的键必须非空。为了能高效的工作,定义键的类必须实现hashcode()方法和equal()方法。这个类是前面java实现的一个继承,并且通常能在实现映象的其他类中更好的使用。

当元素的顺序很重要时选用TreeMap,当元素不必以特定的顺序进行存储时,使用HashMap。Hashtable的使用不被推荐,因为HashMap提供了所有类似的功能,并且速度更快。当你需要在多线程环境下使用时,HashMap也可以转换为同步的。

Properties 一般是把属性文件读入流中后,以键-值对的形式进行保存,以方便读取其中的数据。

4)、Iterator接口

Iterator接口位于java.util包中,它是一个对集合进行迭代的迭代器。

集合容器(如:List、Set、Map等)本身提供了处理元素置入和取出的方式,但是单一选取元素的方法很受限制。所以我们要用Iterator去选取容器中的元素,它将容器转换成一个序列。

Iterator iter=Object.iterator();

while(iter.hasNext()){   }

以下是笔者总结的一些面试中经常会问的相关问题:

1.Collection、Set和List的区别?

Collection对象之间没有指定的顺序,允许有重复元素和多个null元素对象;它是Set和List接口的父类,是一种最通用型的集合接口;

Set各个元素对象之间没有指定的顺序,不允许有重复元素,最多允许有一个null元素对象;

List各个元素对象之间有指定的顺序,允许重复元素和多个null元素对象;

2.LinkedList,ArrayList,Vector,Stack,Queue区别?NodeList区别?

1)LinkedList链式访问,以指针相连,适合于在链表中间需要频繁进行插入和删除操作。

2)ArrayList类似数组的形式,按照序号存储,随机访问速度非常快。

3)Vector向量按照各元素序号存储,数组大小可以动态增长,对于大容量数据存储效率较高。

4)Stack堆栈,先进后出的数组。

这些类的对比与选择:

如果涉及到堆栈队列等操作,应该考虑List中的stack,queue

必看视频!获取2024年最新Java开发全套学习资料 备注Java

对于需要快速插入删除元素,应该使用linkedlist

如果需要快速随机访问元素,应该选用arraylist

如果程序在单线程环境中,选用非同步类

如果在多线程中,选用同步类vector、stack和hashtable以及其子类。

几个面试常见问题:

ArrayList和Vector有什么区别?HashMap和HashTable有什么区别?

Vector和HashTable是线程同步的(synchronized)。性能上,ArrayList和HashMap分别比Vector和Hashtable要好。

讲解java集合的体系结构

A:List、Set、Map是这个集合体系中最主要的三个接口。

其中List和Set继承自Collection接口。

Set不允许元素重复。HashSet和TreeSet是两个主要的实现类。

List有序且允许元素重复。ArrayList、LinkedList和Vector是三个主要的实现类。

Map也属于集合系统,但和Collection接口不同。Map是key对value的映射集合,其中key列就是一个集合。key不能重复,但是value可以重复。HashMap、TreeMap和Hashtable是三个主要的实现类。

SortedSet和SortedMap接口对元素按指定规则排序,SortedMap是对key列进行排序

Comparable和Comparator区别

A:调用java.util.Collections.sort(List list)方法来进行排序的时候,List内的Object都必须实现了Comparable接口。

复制代码

复制代码

java.util.Collections.sort(List list,Comparator c),可以临时声明一个Comparator 来实现排序。

Collections.sort(imageList, new Comparator() {

最后

由于细节内容实在太多了,为了不影响文章的观赏性,只截出了一部分知识点大致的介绍一下,每个小节点里面都有更细化的内容!

小编准备了一份Java进阶学习路线图(Xmind)以及来年金三银四必备的一份《Java面试必备指南》

r() {

最后

由于细节内容实在太多了,为了不影响文章的观赏性,只截出了一部分知识点大致的介绍一下,每个小节点里面都有更细化的内容!

[外链图片转存中…(img-S07jzafn-1716460187678)]

小编准备了一份Java进阶学习路线图(Xmind)以及来年金三银四必备的一份《Java面试必备指南》

[外链图片转存中…(img-LM8ThsTw-1716460187678)]

  • 23
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
java.util包是Java中一个非常重要的包,它包含了一些在Java应用程序中经常使用的类,比如集合类、日期与时间处理类、随机数生成类、正则表达式类等。下面是java.util中一些常用类的使用方法详解。 1. 集合类 Java集合框架定义了一组接口用于表示集合,以及一些实现这些接口的类。这些类包括ArrayList,LinkedList,HashSet,TreeSet,HashMap,TreeMap等。它们提供了各种方法来添加、删除、查找和遍历集合元素。 以ArrayList为例,以下是一些常用方法: ``` // 创建ArrayList对象 ArrayList<String> list = new ArrayList<String>(); // 添加元素 list.add("apple"); list.add("banana"); list.add("orange"); // 获取元素 String first = list.get(0); String last = list.get(list.size() - 1); // 遍历元素 for (String fruit : list) { System.out.println(fruit); } // 删除元素 list.remove("apple"); ``` 2. 日期与时间处理类 Java提供了多种处理日期和时间的类,包括Date,Calendar,SimpleDateFormat等。其中,Date类表示日期和时间,Calendar类是一个抽象类,用于操作日期和时间,SimpleDateFormat类用于格式化日期和时间。 以下是一个使用SimpleDateFormat类将日期格式化为指定字符串的示例: ``` Date date = new Date(); SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String formattedDate = formatter.format(date); System.out.println(formattedDate); ``` 3. 随机数生成类 Java提供了Random类用于生成随机数。它包含了多个方法,可以生成不同类型的随机数,如整数、浮点数、布尔值等。 以下是一个生成1到6之间的随机整数的示例: ``` Random rand = new Random(); int num = rand.nextInt(6) + 1; System.out.println(num); ``` 4. 正则表达式类 Java提供了Pattern和Matcher类用于处理正则表达式。Pattern类表示正则表达式,Matcher类用于在给定输入字符串中匹配该正则表达式。 以下是一个使用正则表达式匹配邮政编码的示例: ``` String zipCodePattern = "\\d{5}"; Pattern pattern = Pattern.compile(zipCodePattern); String input = "12345"; Matcher matcher = pattern.matcher(input); if (matcher.matches()) { System.out.println("Valid zip code"); } else { System.out.println("Invalid zip code"); } ``` 以上是java.util包中一些常用类的使用方法详解,这些类在Java应用程序中经常用到,掌握它们的使用方法对于Java开发者来说非常重要。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值