java_Map集合
import java.util.HashMap; public class MapTest { /** * 1.Map集合是双列几个,一个元素包含两个值(key,value) * 2.Map集合中的元素,key和value的数据类型可以相同也可以不同 * 3.Map集合中的元素Key不可以重复,value可以重复 * 4.Map集合中的元素,key和value一一对应 * * 常用实现类: * java.tuil.hashMap<k,v>集合,implements Map<k,v>接口 * 1。hashMap集合底层是哈希表,查询的速度特别快 * jdk1.8前:数组+单向链表 * jdk1.8后:数组+单项链表/红黑树 * 2.hashMap是无序集合 * * LinkedHashMap特点: * 1.LinkedHashMap集合迪底层是哈希表+链表 * 2.LinkedHashMap集合是一个有序的集合,储存元素和取出元素的顺序是一致的 * * 方法: * put(k,v):添加,返回v:key不重复返回v是null,key重复会替换value返回被替换值 * remove(object key):把指定键对应的value删除,返回删除元素,key存在返回v,key不存在返回null * get(k):k存在返回value,k不存在返回null * containskey(k):判断是否包含k,包含返回true,不包含返回false */ public static void main(String[] args) { HashMap<String, String> hashMap = new HashMap<>(); String put1 = hashMap.put("杨过", "小龙女"); String put2 = hashMap.put("冷锋", "龙小云"); String put3 = hashMap.put("A", "B"); System.out.println("put1:"+put1); System.out.println("put2:"+put2); System.out.println("put3:"+put3); System.out.println(hashMap); System.out.println(hashMap.get("杨过")); hashMap.remove("杨过"); System.out.println(hashMap); System.out.println(hashMap.containsKey("杨过")); }
/** * 遍历: * keySet():所有key添加到set集合中 * 遍历set集合获取map结合中的每一个key * 通过getkey找到value */ public static void main(String[] args) { HashMap<String, String> hashMap = new HashMap<>(); String put1 = hashMap.put("杨过", "小龙女"); String put2 = hashMap.put("冷锋", "龙小云"); String put3 = hashMap.put("A", "B"); Set<String> strings = hashMap.keySet(); for (String string : strings) { System.out.println(hashMap.get(string)); } }
/** Entry键值对对象被: * 在map接口中有一个内部类接口Entry * 作用:当map结合一创建,就在map集合中创建一个Entry对象,用来记录键与值(键值对对象,键与值的映射关系) * 方法: * entrySet():把map集合内部的多个Entry对象取出来存储到一个Set集合中 * getkey * getvalue */ public static void main(String[] args){ HashMap<String, String> hashMap = new HashMap<>(); String put1 = hashMap.put("杨过", "小龙女"); String put2 = hashMap.put("冷锋", "龙小云"); String put3 = hashMap.put("A", "B"); Set<Map.Entry<String, String>> entries = hashMap.entrySet(); for (Map.Entry<String, String> entry : entries) { System.out.println(entry.getKey()); System.out.println(entry.getValue()); } } }
/** hashMap:存储自定义类型键值 * map集合保证key是唯一的:作为key元素必须重写hashCode和equals方法保证key的唯一性 * * LinkedHashMap entends HashMap * 哈希表+链表 * key不允许重复,有序集合 * * * Hashtable集合 implements Map接口 * 底层是哈希表,是线程安全的速度慢 *Hashtable集合不能储存null值,null键 * Hashtable和vector集合一样,在jdk1.2版本之后被先进的集合(HashMap,ArrayList)取代了 *Hashtable的子类properties一样活跃在历史舞台 * properties集合是一个唯一和IO流相结合的集合 * * Map集合练习: * 需求:计算一个字符串中每个字符出现的个数 * 1.使用Scanner获取用户输入字符串 * 2.创建Map集合,key是字符串中的字符,value是字符个数 * 3.遍历字符串,获取每一个字符 * 4.使用获取到的字符去Mao集合中判断key是否存在 * 如果存在: * 通过key获取value并++ * 如果不存在: * put(k,1) * 5.遍历集合 * * jdk9对集合添加的优化: * list接口,Set接口,Map接口:增加一个静态的方法of,可以给集合一次添加多个元素 * 使用前提:当几个中存储的元素的个数已经确定了,不在改变 * 注意事项: * 1.of方法只适用于List接口,Set接口,Map接口,不适用于接口的实现类 * 2.of方法的返回值是一个不能改变的集合,集合不能在使用add,put方法添加元素,会抛出异常 * 3.Set接口和Map接口在调用of方法时不能有重复元素,否则会抛出异常 * * */
java_Map集合的更多相关文章
- java基础集合经典训练题
第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...
- .Net多线程编程—并发集合
并发集合 1 为什么使用并发集合? 原因主要有以下几点: System.Collections和System.Collections.Generic名称空间中所提供的经典列表.集合和数组都不是线程安全 ...
- 一起学 Java(三) 集合框架、数据结构、泛型
一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...
- 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)
建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...
- java基础_集合List与Set接口
List接口继承了Collection的方法 当然也有自己特有的方法向指定位置添加元素 add(索引,添加的元素); 移除指定索引的元素 remove(索引) 修改指定索引的元素 set ...
- Java基础Collection集合
1.Collection是所有集合的父类,在JDK1.5之后又加入了Iterable超级类(可以不用了解) 2.学习集合从Collection开始,所有集合都继承了他的方法 集合结构如图:
- 轻量级“集合”迭代器-Generator
Generator是PHP 5.5加入的新语言特性.但是,它似乎并没有被很多PHP开发者广泛采用.因此,在我们了解PHP 7对Generator的改进之前,我们先通过一个简单却显而易见的例子来了解下G ...
- Asp.net MVC 传递数据 从前台到后台,包括单个对象,多个对象,集合
今天为大家分享下 Asp.net MVC 将数据从前台传递到后台的几种方式. 环境:VS2013,MVC5.0框架 1.基本数据类型 我们常见有传递 int, string, bool, double ...
- 这些.NET开源项目你知道吗?.NET平台开源文档与报表处理组件集合(三)
在前2篇文章这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧 和这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,大伙热情高涨.再次拿出自己的私货,在.NET平台 ...
随机推荐
- 好久不见的博客咯!——没有可持久化的可持久化treap
每每想要去了解可持久化treap这个好写好调的东东,然后就发现网上只有一个人的——SymenYang的!在此我必须得把他批判一番——写方法不贴代码是什么心态!而且写出来的是有问题的呀!害人不浅! 好吧 ...
- 「题解」:x
问题 A: x 时间限制: 1 Sec 内存限制: 256 MB 题面 题面谢绝公开. 题解 赛时想到了正解并且对拍了很久.对拍没挂,但是评测姬表示我w0了……一脸懵逼. 不难证明,如果对于两个数字 ...
- Android中的APK,TASK,PROCESS,USERID之间的关系
开发Android已经有一段时间了,今天接触到底层的东西,所以对于进程,用户的id以及Android中的Task,Apk之间的关系,要做一个研究,下面就是研究结果: apk一般占一个dalvik,一个 ...
- 二分+mu函数实质及应用(原理)!——bzoj2440好题
首先想到用二分来判断 不是平方数的倍数,即没有次数>=2的质因子显然用容斥原理,即所有答案-1个质因子的平方的所有倍数+2个质因子的所有平方倍...等价于对于每个数,如果它有奇数个质因子,那么其 ...
- delphi directui 做界面的一个例子
现在很多CS系统或者软件界面都做的非常好看,比如:QQ皮肤,迅雷下载,360杀毒界面等.这些都是运用的流行的DIRECTUI 技术,基本上有的资料都是基于C++的,很少有同仁将C++下的DIRECT ...
- 秒懂机器学习---分类回归树CART
秒懂机器学习---分类回归树CART 一.总结 一句话总结: 用决策树来模拟分类和预测,那些人还真是聪明:其实也还好吧,都精通的话想一想,混一混就好了 用决策树模拟分类和预测的过程:就是对集合进行归类 ...
- random,time,sys,os,序列化模块
random模块(随机数模块) 取随机小数: random.random() 取0-1之间的小数 random.uniform(x, y) 取x-y之间的小数 取随机整数: random.randin ...
- 新版本Mongo4.0 新建用户
db.createUser( { user: “admin”, pwd: “xxx”, roles: [ { role: “userAdminAnyDatabase”, db: “admin” } ] ...
- Rabbit MQ 基础入门
Rabbit MQ 学习(一)基础入门 简介 RabbitMQ 简介 为什么选择 RabbitMQ RabbitMQ 的模型架构是什么? AMQP 协议是什么? AMQP 常用命令 概念 生产者和消费 ...
- HDU 3966 /// 树链剖分+树状数组
题意: http://acm.hdu.edu.cn/showproblem.php?pid=3966 给一棵树,并给定各个点权的值,然后有3种操作: I x y z : 把x到y的路径上的所有点权值加 ...