Java编程集合之HashMap

简介: Map 映射 通过某一个key可以直接定位到一个value值 存储的方式以 键值对 存储 key-value key无序无重复 value无序可重复 key无序还是一样,指的是存入顺序与取得顺序不一致 key无重复当然指的是 元素不能一致 1.map基本使用 HashMap TreeMap Properties HashMap 1.包 java.util 2.如何创建对象 3.基本方法增删改查 增put(key,value) 存放一组映射关系 key-value

知识回顾

集合

   Collection  Map

   以value形式  以key-value形式

   List  Queue  Set

   Set

   特点  无序无重复

   无序: 添加的顺序 获取的顺序不一致 (不是集合本身是否有序 Tree自然有序)

   无重复: 添加的元素不能一致 (如果出现重复元素 只存第一个 不再存入)

   HashSet(HashMap--->数据存储结构 散列表)

   TreeSet(TreeMap--->数据存储结构 二叉树)

   set集合家族的基本使用

   增删改查

   add(E e)   remove(E e)  没有修改

   iterator迭代器(增强for)   size();

       hasNext();

       E = next();

   set集合的无重复特性

   HashSet 无重复原则有两个方法同时起作用

   equals hashCode

   默认比较的是两个对象的地址  若第二个对象地址与之前的一致  不再存入

   如果想要改变其比较的规则  可以重写上述两个方法

   TreeSet 无重复原则有一个方法起作用

   compareTo

   上述这个方法不是每一个对象都有的

   若想要将某一个对象存入TreeSet集合中

   需要让对象所属的类实现接口Comparable

   实现接口后将compareTo方法重写  返回值int  

   负数靠前排布 整数排列靠后

Map   映射   通过某一个key可以直接定位到一个value值

   存储的方式以  键值对  存储   key-value

   key无序无重复   value无序可重复

   key无序还是一样,指的是存入顺序与取得顺序不一致

   key无重复当然指的是 元素不能一致

   1.map基本使用

   HashMap

   TreeMap

   Properties  

   HashMap

   1.包 java.util

   2.如何创建对象

   3.基本方法

增删改查

   增put(key,value) 存放一组映射关系   key-value

   1.key存储的顺序与取得顺序不同

   2.不同的key可以存储相同的value

   3.key若有相同的 则将 原有的value覆盖而不是拒绝存入(跟set刚好相反)

       删E = remove(key);

       改put(key,value1)    put(key,value2)

       replace(key,newValue)

       查E = get(key)

       遍历map集合? key不一定什么样

       获取到所有的key 遍历key 通过key获取value

       Set<Key> = keySet()获取全部的key

       Set<Entry> = entrySet();

       size();

   4.除了上述几个常用的方法外  其他API中提供的方法

       clear   containsKey(key)   containsValue(value)

       getOrDefault(key,defaultValue);

       如果key存在就返回对应的value 若没有找到则返回默认值

       isEmpty()

       putAll(map)

       putIfAbsent(key,value);//如果key不存在才向集合内添加  如果key存在就不添加啦

   5.map集合在什么情形下用?

       1.想要存储一组元素

       数组  or  集合    

       如果存储的元素以后长度不变用数组  

       如果长度以后不确定 用集合

       2.如果发现长度以后不确定--->集合

       List  Set  Map

       List家族有序的   存储有顺序用这个

       ArrayList 更适合遍历轮询

       LinkedList 更适合插入和删除

       Stack LIFO

       Set家族无重复    存储元素希望自动去掉重复元素用这个

       Hash 性能更高

       Tree 希望存进去的元素自动去重复  同时还能自动排序

       Map家族k-v      通过唯一的k快速找寻v用这个

       Hash 性能更高

       Tree 希望存进去的元素key自动排序

   6.登录小流程

       能体会每一个不同集合的特点

   7.HashMap底层的数据结构存储

       散列表的形式 数组+链表

       Person对象存入HashMap中?  可以

       hashCode方法---->不同的对象 可以产生相同的hashCode码的

       不同的hashCode码-->不同的对象

目录
相关文章
|
1月前
|
Java
如何在Java中进行多线程编程
Java多线程编程常用方式包括:继承Thread类、实现Runnable接口、Callable接口(可返回结果)及使用线程池。推荐线程池以提升性能,避免频繁创建线程。结合同步与通信机制,可有效管理并发任务。
140 6
|
1月前
|
IDE Java 编译器
java编程最基础学习
Java入门需掌握:环境搭建、基础语法、面向对象、数组集合与异常处理。通过实践编写简单程序,逐步深入学习,打牢编程基础。
176 0
|
2月前
|
SQL Java 数据库
2025 年 Java 从零基础小白到编程高手的详细学习路线攻略
2025年Java学习路线涵盖基础语法、面向对象、数据库、JavaWeb、Spring全家桶、分布式、云原生与高并发技术,结合实战项目与源码分析,助力零基础学员系统掌握Java开发技能,从入门到精通,全面提升竞争力,顺利进阶编程高手。
528 1
|
1月前
|
安全 前端开发 Java
从反射到方法句柄:深入探索Java动态编程的终极解决方案
从反射到方法句柄,Java 动态编程不断演进。方法句柄以强类型、低开销、易优化的特性,解决反射性能差、类型弱、安全性低等问题,结合 `invokedynamic` 成为支撑 Lambda 与动态语言的终极方案。
144 0
|
2月前
|
Java 大数据 API
Java Stream API:现代集合处理与函数式编程
Java Stream API:现代集合处理与函数式编程
234 100
|
2月前
|
Java API 数据处理
Java Stream API:现代集合处理新方式
Java Stream API:现代集合处理新方式
266 101
|
2月前
|
Java 开发者
Java并发编程:CountDownLatch实战解析
Java并发编程:CountDownLatch实战解析
431 100
|
1月前
|
存储 算法 安全
Java集合框架:理解类型多样性与限制
总之,在 Java 题材中正确地应对多样化与约束条件要求开发人员深入理解面向对象原则、范式编程思想以及JVM工作机理等核心知识点。通过精心设计与周密规划能够有效地利用 Java 高级特征打造出既健壮又灵活易维护系统软件产品。
72 7
|
2月前
|
存储 Java Go
对比Java学习Go——函数、集合和OOP
Go语言的函数支持声明与调用,具备多返回值、命名返回值等特性,结合`func`关键字与类型后置语法,使函数定义简洁直观。函数可作为一等公民传递、赋值或作为参数,支持匿名函数与闭包。Go通过组合与接口实现面向对象编程,结构体定义数据,方法定义行为,接口实现多态,体现了Go语言的简洁与高效设计。
|
存储 安全 Java
【Java集合类面试二十五】、有哪些线程安全的List?
线程安全的List包括Vector、Collections.SynchronizedList和CopyOnWriteArrayList,其中CopyOnWriteArrayList通过复制底层数组实现写操作,提供了最优的线程安全性能。