java的容器类有哪些实现方式_Java基础--容器类

面试官:Java的容器类你有什么了解吗?

-:额,没有用过....

面试官:你肯定用过,但你没有注意过....

-:应该是吧....

你知道什么是容器类吗?Java容器可以说是增强程序员编程能力的基本工具,本文将与您一起理解容器类,看完之后你也许会恍然大悟,这原来就是容器类啊,一起避免面试时的尴尬!!!!

1.容器的用途

如果对象的数量与生命周期都是固定的,自然我们也就不需要很复杂的数据结构。

我们可以通过创建引用来持有对象,如

Class clazz;

也可以通过数组来持有多个对象,如

Class[] clazs = new Class[10];

然而,一般情况下,我们并不知道要创建多少对象,或者以何种方式创建对象。数组显然只能创建固定长度的对象,为了使程序变得更加灵活与高效,Java类库提供了一套完整的容器类,具备完善的方法来解决上述问题。

2.容器的类别

3f39c45c3318

容器的类别

]

观察上图,我们可以得出容器主要分为两种类型,两个接口Collection与Map定义了两类不同的对象存储方式。

Collection用以保存单一的元素,Map保存关联键值对。通过泛型来指定容器存放的数据类型。** Iterator 设计的目的是在未知容器具体的类型的情况下,用来遍历容器元素。剩下的容器类型都是继承了这两个接口。

在实际编码中,通过向上转型**为接口,在其与代码中都使用这个接口是非常普遍的使用方式。如下:

import java.util.*;

public class TestCollection {

public static void main(String[] args){

Collection c = new ArrayList();

for(int i = 0; i < 10; i++){

c.add(i);

}

for(Integer i : c){

System.out.print(i + ", ");

}

}

}

注:由于List接口的方法比Collection更为丰富,所以 实际应用中,ArrayList向上转型为List更为合适。

刚刚接触容器的朋友们可能会只把Collection与Map当做接口,实际上并非如此,容器中的接口其实有六个。

3. 容器中的七大接口

1.Collection接口

2.Map接口

3.Set接口

4.List接口

5.Queue接口

6.Iterator接口

7.Comparable接口

其中List, Queue和Set接口继承了Collection接口,剩下的接口之间都是相互独立的,无继承关系。List和Set接口主要是为了区分是否要包含重复元素,Iterater迭代器则是为了更灵活的迭代集合,与foreach一起使用。Comparable接口则用于比较。

4. 各类容器的功能(主要实现类分析)

.Collection接口

List接口(相比Collection, 添加了新的方法)

ArrayList

实现List接口,类似于动态数组,适用于大量随机访问的情况。但插入和删除的代价非常高昂

LinkedList

实现List接口,类似于链表,也提供了优化的顺序访问。在插入和删除方面代价低廉,随机访问代价较高

Set接口(方法与Collection完全相同)

HashSet

HashSet使用了散列函数实现,极大的提高了访问速度,集合中的对象是没有顺序的。存入HashSet的对象必须定义hashCode()

TreeSet

TreeSet使用红黑树来实现存储元素, 红黑树的好处是可以插入之后维持集合的有序性,从而保证在遍历的时候,按照递增的顺序获取对象。

LinkedHashSet

顾名思义,LinkedHashSet使用了链表来保持插入顺序,不过为了提高查询效率,也使用了散列。

Queue接口

LinkedList

LinkedList实现了Queue接口,提供了方法支持队列的行为,在以后的系列我们会深入讲解如何用LinkedList实现队列。

PriorityQueue

与普通队列不同,优先队列每次弹出的是优先级最高的元素。可以通过提供自己的Comparator来修改默认的优先级顺序。

Map接口

HashMap

HashMap通过散列机制,用来快速访问,适用于添加、删除和定位映射关系。允许键对象为null,但因为键对象是唯一的,所以只允许有一个null。

TreeMap

TreeMap保持"key"处于排序状态,不允许键值为null,访问速度不如HashMap

LinkedHashMap 。

LinkedHashMap保持元素插入时顺序,同时提供散列实现快速访问 。

关于Map的散列实现是非常重要的,实现Map的原理(关联数组等)。

import java.util.*;

public class IntegerSet{

private static Random rand;

public static void main(String[] args){

rand = new Random(47);

Set intset = new HashSet();

for(int i = 0; i < 10000; i++){

intset.add(rand.nextInt(30));

}

System.out.println(intset);

}

}

5.总结

通过本文的回顾,相信读者对容器的用途,分类,以及容器的层次结构与一些常用容器的基本功能和用法有了较为清晰地了解。然而,想要更好的使用容器类,还必须了解每种容器具体的方法,源码,以及线程安全的实现,但是以上这些应对一下面试官应该还可以吧。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/528713.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java集合系列_Java集合系列01-Java集合概述

1.Java集合基本概念在编程中&#xff0c;常常需要集中存放多个数据。从传统意义上讲&#xff0c;数组是我们的一个很好的选择&#xff0c;前提是我们事先已经明确知道我们将要保存的对象的数量&#xff0c;因为数组长度在初始化时指定&#xff0c;意味着只能保存定长的数据。一…

java黄金连分数_蓝桥杯 | Java B组省赛真题练习——黄金连分数-Go语言中文社区...

标题: 黄金连分数黄金分割数0.61803... 是个无理数&#xff0c;这个常数十分重要&#xff0c;在许多工程问题中会出现。有时需要把这个数字求得很精确。 对于某些 精密工程&#xff0c;常数的精度很重要。也许你听说过哈勃太空望远镜&#xff0c;它首次升空后就发现了一处人工加…

python 数组维度_python – 非常基本的Numpy数组维度可视化

NumPy中ndarray的解剖结构如下所示&#xff1a;(来源&#xff1a;Physics Dept, Cornell Uni)一旦离开2D空间并进入3D或更高维空间,行和列的概念就不再有意义了.但是你仍然可以直观地理解3D阵列.例如,考虑你的例子&#xff1a;In [41]: bOut[41]:array([[[ 1, 2, 3],[ 4, 5, 6]…

Java捕获异常密码_Java捕获异常的问题

---恢复内容开始---在Java编译过程中&#xff0c;有时候会出现输入未按照规定输入的情况&#xff0c;此时需要警告用户输入错误&#xff0c;这就会是程序运行过程中出现异常。异常就是可预测但是又没办法消除的一种错误。所以在编写过程中&#xff0c;为了在程序当中不发生这样…

java作业四_Java第四次作业

1.(二次方程式)为二次方程式ax2bxc0设计一个名为QuadraticEquation的类。这类包括&#xff1a;(1)代表三个系数的私有数据域a、b、c(2)一个参数为a、b和c的构造方法(3)a、b、c的三个get方法(4)一个名为getDiscriminant()的方法返回判别式&#xff0c;b2-4ac(5)一个名为getRoot1…

java collectiongroup 类_Java中的collection集合类型总结

java集合是java提供的工具包&#xff0c;包含了常用的数据结构&#xff1a;集合、链表、队列、栈、数组、映射等。java集合工具包位置是java.util.*java集合主要可以划分为4个部分&#xff1a;list列表、set集合、map映射、工具类(iterator迭代器、enumeration枚举类、arrays和…

php 鼠标点击图片放大,css3如何实现鼠标放上图片放大?(附代码)

在css3的学习中&#xff0c;我们会经常做一些小的动画效果&#xff0c;这感觉非常有趣&#xff0c;所以今天的这篇文章将给大家来介绍关于css3实现图片放大的一个效果&#xff0c;有兴趣的小伙伴可以看一下。我们都知道css3中增加了一个transform属性应用于元素的2D或3D转换&am…

脉位调制解调 matlab,通信原理与matlab仿真v2 第五章 DBPSK调制解调器(1)

在毕业设计的相关课程中&#xff0c;已经提及了这个DPSK调制方式。不过如果把它放在理论教学课程中来讲&#xff0c;就需要补充一些基本知识。当然还会给同学们看一下实际在卫星通信中使用的DBPSK程序。之前讲到了BPSK&#xff0c;回顾一下发送滤波器的知识吧。由于信号要在信道…

matlab地址数据类型uns,使用matlab生成sine波mif文件

使用matlab生成sine波mif文件作者&#xff1a;lee神在使用altera 的FPGA中的rom過程中常常會使用到.mif文件或.hex文件。對於初學者&#xff0c;無論mif還是hex都是很令人疑惑的東西&#xff0c;這里就對mif文件的格式及其創建做一點簡單的說明。Mif是memory initialization fi…

OpenAI科学家Hyung Won Chung演讲精华版

文章目录 第一个观点&#xff1a;涌现第二个观点&#xff1a;如何扩大规模1、标记化2、嵌入3、计算4、评估&#xff08;损失函数&#xff09;5、反向传播 最近从Google跳槽到OpenAI的AI科学家 Hyung Won Chung 比较拗口&#xff0c;我就简称尚哥了 他最近做了一个技术演讲 …

php如何实现购物时数量增减,1、vuex状态管理--购物车数量增减

GIF.gif1、购物车数量增减-import { mapState,mapMutations} from vuex //引入mapState、mapMutations映射函数export default{computed:{...mapState({changableNum:state > state.headerStatus.changableNum, //用模块headerStatus里的状态 changableNumdisabled:state &g…

oracle中存储过程和函数有什么区别,Oracle中存储过程和函数的区别

Oracle中存储过程和函数的区别存储过程和函数&#xff1a; www.2cto.com例子&#xff1a;[sql]//创建过程create or replace procedure add_emailinfo(namee email_info.fullname%type &#xff0c;address email_info.email_address%type )isbegininsert into email_info(ful…

oracle 查询结果升序,Oracle学习日志-8(查询结果排序)

要用到的表如下书上写到&#xff0c;上面的查询结果排序是随机的&#xff0c;再执行几次结果可能不同&#xff0c;但是我执行多次后&#xff0c;查询结果的排序都是如此&#xff0c;是因为oracle的默认处理方式是按照物理储存顺序查询的&#xff0c;而我在插入记录的时候都是按…

linux下如何搜索某个文件,技术|如何在 Linux 中查找一个文件

对于新手而言&#xff0c;在 Linux 中使用命令行可能会非常不方便。没有图形界面&#xff0c;很难在不同文件夹间浏览&#xff0c;找到需要的文件。本篇教程中&#xff0c;我会展示如何在 Linux 中查找特定的文件。第一步要做的是find 命令&#xff0c;另外一种是使用 locate 命…

linux 安装系统 逻辑卷,Linux逻辑卷工具lvm的使用教程

创建逻辑卷(LVM)详细方法&#xff1a;STEP 1&#xff1a;首先用fdisk命令建立物理分区&#xff0c;然后将每个分区类型转换为LVM类型&#xff0c;编号为8e&#xff0c;如果是对整个磁盘建立pv的话这步可以忽略。STEP 2&#xff1a;使用pvcreate命令建立pv&#xff0c;也就是物理…

linux下su命令进不去,Linux系统中的切换用户Su命令,教你如何使用su命令,包括注意事项...

在本文中&#xff0c;我们将解释如何使用su命令&#xff0c;su(替换或切换用户的缩写)实用程序允许你使用其他用户的权限运行命令&#xff0c;默认情况下是root用户。使用su是在当前登录会话中切换到管理帐户的最简单方法&#xff0c;当root用户不允许通过ssh或使用GUI显示管理…

linux收回用户执行权限,Linux之文件权限管理命令

一、查看文件属性。1、命令ls -l filename 查看长格式形式查看文件详细属性。ls -l file1 ##查看文件file1的详细属性结果&#xff1a;- |rw-r--r--| 1 |kiosk| kiosk| 0| Jul 21 09:18 | file1[1] [2] [3] [4] [5] [6] [7] [8][1] 文件的类型—##空文件&#xff0c;或者文本d#…

linux服务器操作系统日志都有哪些,Linux操作系统服务器日志管理详解

Linux操作系统服务器日志管理详解Linux操作系统服务器日志管理详解日志对于安全来说&#xff0c;非常重要&#xff0c;他记录了系统每天发生的各种各样的事情&#xff0c;你可以通过他来检查错误发生的原因&#xff0c;或者受到攻击时攻击者留下的痕迹。日志主要的功能有&#…

linux7配置dns服务器,centOS7搭建DNS服务器配置详解

写在前言&#xff1a;DNS服务器中 named-checkconf -z /etc/named.conf 命令用来检查所有与DNS有关的配置文件&#xff0c;若有错误&#xff0c;会直接提示&#xff0c;可以代替相关的所有检查命令。通过yum安装所需的BIND软件&#xff0c;系统光盘中自带了BIND服务的安装文件。…

linux重新安装xrog文件,Linux下重新生成xorg.conf

较新版本的Linux系统都已经没有xorg.conf文件&#xff0c;但是有时候为了对显示做微调或为了支持多屏显示等原因&#xff0c;还需要手工生成一个xorg.c较新版本的Linux系统都已经没有xorg.conf文件&#xff0c;但是有时候为了对显示做微调或为了支持多屏显示等原因&#xff0c;…