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码-->不同的对象

目录
相关文章
|
2天前
|
缓存 负载均衡 安全
|
1天前
|
设计模式 算法 安全
Java编程中的设计模式:提升代码的可维护性和扩展性
【8月更文挑战第19天】在软件开发的世界里,设计模式是解决常见问题的一种优雅方式。本文将深入探讨Java编程语言中常用的几种设计模式,并解释如何通过这些模式来提高代码的可维护性和扩展性。文章不涉及具体的代码实现,而是侧重于理论和实践相结合的方式,为读者提供一种思考和改善现有项目的新视角。
|
1天前
|
安全 Java 测试技术
深入探讨Java安全编程的最佳实践,帮助开发者保障应用的安全性
在网络安全日益重要的今天,确保Java应用的安全性成为了开发者必须面对的课题。本文介绍Java安全编程的最佳实践,包括利用FindBugs等工具进行代码审查、严格验证用户输入以防攻击、运用输出编码避免XSS等漏洞、实施访问控制确保授权访问、采用加密技术保护敏感数据等。此外,还强调了使用最新Java版本、遵循最小权限原则及定期安全测试的重要性。通过这些实践,开发者能有效提升Java应用的安全防护水平。
5 1
|
2天前
|
Java 开发者
在Java编程中,if-else与switch作为核心的条件控制语句,各有千秋。if-else基于条件分支,适用于复杂逻辑;而switch则擅长处理枚举或固定选项列表,提供简洁高效的解决方案
在Java编程中,if-else与switch作为核心的条件控制语句,各有千秋。if-else基于条件分支,适用于复杂逻辑;而switch则擅长处理枚举或固定选项列表,提供简洁高效的解决方案。本文通过技术综述及示例代码,剖析两者在性能上的差异。if-else具有短路特性,但条件增多时JVM会优化提升性能;switch则利用跳转表机制,在处理大量固定选项时表现出色。通过实验对比可见,switch在重复case值处理上通常更快。尽管如此,选择时还需兼顾代码的可读性和维护性。理解这些细节有助于开发者编写出既高效又优雅的Java代码。
6 2
|
2天前
|
Java 开发者
在Java编程的广阔天地中,if-else与switch语句犹如两位老练的舵手,引领着代码的流向,决定着程序的走向。
在Java编程中,if-else与switch语句是条件判断的两大利器。本文通过丰富的示例,深入浅出地解析两者的特点与应用场景。if-else适用于逻辑复杂的判断,而switch则在处理固定选项或多分支选择时更为高效。从逻辑复杂度、可读性到性能考量,我们将帮助你掌握何时选用哪种语句,让你在编程时更加得心应手。无论面对何种挑战,都能找到最适合的解决方案。
6 1
|
2天前
|
搜索推荐 Java 程序员
在Java编程的旅程中,条件语句是每位开发者不可或缺的伙伴,它如同导航系统,引导着程序根据不同的情况做出响应。
在Java编程中,条件语句是引导程序根据不同情境作出响应的核心工具。本文通过四个案例深入浅出地介绍了如何巧妙运用if-else与switch语句。从基础的用户登录验证到利用switch处理枚举类型,再到条件语句的嵌套与组合,最后探讨了代码的优化与重构。每个案例都旨在帮助开发者提升编码效率与代码质量,无论是初学者还是资深程序员,都能从中获得灵感,让自己的Java代码更加优雅和专业。
5 1
|
2天前
|
Java
在Java编程的广阔天地中,条件语句是控制程序流程、实现逻辑判断的重要工具。
在Java编程中,if-else与switch作为核心条件语句,各具特色。if-else以其高度灵活性,适用于复杂逻辑判断,支持多种条件组合;而switch在多分支选择上表现优异,尤其适合处理枚举类型或固定选项集,通过内部跳转表提高执行效率。两者各有千秋:if-else擅长复杂逻辑,switch则在多分支选择中更胜一筹。理解它们的特点并在合适场景下使用,能够编写出更高效、易读的Java代码。
5 1
|
4天前
|
存储 Java API
|
4天前
|
存储 缓存 安全
深度剖析Java HashMap:源码分析、线程安全与最佳实践
深度剖析Java HashMap:源码分析、线程安全与最佳实践
|
1天前
|
安全 Java 程序员
阿里开发手册 嵩山版-编程规约 (四)OOP规约-Java程序员必看知识点!!!
《阿里开发手册 嵩山版》的OOP规约部分强调了面向对象编程的最佳实践,包括正确使用静态方法、覆写方法的注解、可变参数的使用、接口的稳定性、equals和compareTo方法的使用、BigDecimal的正确比较、包装类与基本数据类型选择、POJO类的属性和方法设计等,以提升代码的质量和维护性。
9 0