Java—双列集合

2024-08-26 17:04
文章标签 java 集合 双列

本文主要是介绍Java—双列集合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

双列集合体系结构

Map

Map的遍历方式

键找值遍历

键值对遍历

Lambda遍历

HashMap

LinkedHashMap

TreeMap

TreeMap自定义排序方式

底层原理

集合使用总结


双列集合体系结构

双列集合的特点
1. 双列集合一次需要存一对数据,分别为键和值;
2. 键不能重复,但值可以重复;
3. 键和值是一一对应的,每一个键只能找到自己对应的值;
4. 键+值这个整体,我们称之为“键值对”或者“键值对对象”,在Java中叫做“Entry对象“。


Map

Map是双列集合的顶层接口,它的功能是全部双列集合都可以继承使用的。

V put(K key, V value)                    //添加元素
V remove(object key)                     //根据键删除键值对元素
void clear()                             //移除所有的键值对元素
boolean containsKey(object key)          //判断集合是否包含指定的键
boolean containsValue(object value)      //判断集合是否包含指定的值
boolean isEmpty()                        //判断集合是否为空
int size()                               //返回集合的长度,也就是集合中键值对的个数

put方法细节部分:
在添加数据时,如果键不存在,则直接将键值对对象添加到map集合中,方法返回null;
在添加数据时,如果键存在,则将原有的键值对对象覆盖,并返回被覆盖的值。


Map的遍历方式

键找值遍历

首先获取所有的键并存放到单列集合中,再通过遍历单列集合获取值,代码示例如下。

Map<String, String> map = new HashMap<>();
map.put("111", "aaa");
map.put("222", "bbb");
map.put("333", "ccc");//获取所有的键,并存放到单列集合中
Set<String> keys = map.keySet();//Lamdba遍历
keys.forEach((key) -> {String value = map.get(key);System.out.println(key + " = " + value);
});

键值对遍历

Map<String, String> map = new HashMap<>();
map.put("111", "aaa");
map.put("222", "bbb");
map.put("333", "ccc");//获取所有的键值对
Set<Map.Entry<String, String>> entries = map.entrySet();//遍历entries集合,得到每一个键值对
entries.forEach(entry -> {String key = entry.getKey();String value = entry.getValue();System.out.println(key + " = " + value);
});

Lambda遍历

//Map集合的第一种遍历方式
Map<String, String> map = new HashMap<>();
map.put("111", "aaa");
map.put("222", "bbb");
map.put("333", "ccc");//遍历entries集合,得到每一个键值对
map.forEach((key, value) -> System.out.println(key + " = " + value));

HashMap

HashMap的特点
1. HashMap是Map接口的实现类之一;
2. HashMap没有额外需要学习的特有方法,直接使用Map中的方法就可以了;
3. 特点是由决定的:无序、不重复、无索引;
4. HashMap与Hashset的底层原理是相同的,都是哈希表结构。只是HashMap的哈希值是由键决定的,与值无关。

注意
1. HashMap依赖hashcode方法和equals方法保证键的唯一;
2. 如果键存储的是自定义对象,需要重写hashcode和equals方法;
3. 如果值存储自定义对象,不需要重写hashcode和equals方法,因为HashMap中值可以不唯一。


LinkedHashMap

HashMap没有额外需要学习的特有方法,直接使用Map中的方法就可以了。 


TreeMap

1. TreeMap跟TreeSet底层原理一样,都是红黑树结构;
2. 由决定特性:不重复、无索引、可排序
3. 可排序:对键进行排序;
4. TreeMap没有额外需要学习的特有方法,直接使用Map中的方法就可以了。 

TreeMap自定义排序方式

Comparable比较器接口中compare方法返回值的特点
负数:表示当前要添加的元素是小的,存左边
正数:表示当前要添加的元素是大的,存右边
0:表示当前要添加的元素已经存在,舍弃

方式一
默认排序/自然排序:通过集合存储的Javabean类自身实现Comparable接口,编写比较规则。

public class Student implements Comparable<Student> {private String name;private int age;...//按照年龄从小到大排序,若年龄相同,则按照姓名字符串排序@Overridepublic int compareTo(Student o) {int i = this.getAge() - o.getAge();i = i == 0 ? this.getName().compareTo(o.getName()) : i;return i;}}

方式二
比较器排序:创建TreeMap对象时,传递比较器Comparator类并编写排序规则。

//根据键降序排序
TreeMap<Integer, String> treeMap = new TreeMap<>((o1, o2) -> o2 - o1);treeMap.put(2, "电脑");
treeMap.put(1, "手机");
treeMap.put(3, "笔记本");treeMap.forEach((key, value) -> {System.out.println(key + " : " + value);
});

使用原则:默认使用第一种,如果第一种不能满足当前需求,则使用第二种。 


底层原理

1. TreeMap添加元素时,键是否需要重写hashcode和equals方法?
答:不需要,TreeMap底层是通过比较器判断元素的大小与相等的,而HashMap底层是通过hashcode和equals方法来保证键的唯一性的。

2. HashMap是哈希表结构的,JDK8开始由数组,链表,红黑树组成。既然有红黑树,HashMap的键是否需要实现compareable接口或者传递比较器对象呢?
答:不需要,因为在HashMap底层,默认是利用哈希值的大小关系来创建红黑树的。

3. TreeMap和HashMap谁的效率更高?
如果是最坏情况:在HashMap添加了8个元素,这8个元素形成了链表,此时TreeMap的效率会更高,但是这种情况出现的几率非常的少。一般而言,还是HashMap的效率更高。


集合使用总结

默认使用HashMap(效率最高)
若要求键值对存取有序:LinkedHashMap
若要求对键值对进行排序:TreeMap

这篇关于Java—双列集合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1109159

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定