Java集合之Map接口
Map使用键值对来存储数据,将键映射到值对象,一个映射不能包含重复的键,每一个键最多只能映射到一个值。Map接口的具体实现类:HashMap,Hashtable,TreeMap,LinkedHashMap
1)HashMap
基于哈希表(哈希表学习地址)的Map接口实现。允许使用null值和null键,不保证映射的顺序,特别是不保证顺序恒久不变。它除了非同步和允许使用null外,与Hashtable大致相同。
HashMap实现原理:
1.HashMap默认数组大小为16,加载因子为0.75,当数组使用量达到数组长度*加载因子时,需要进行扩充。
2.HashMap是以数组为头,连接链表形成的(要计算key的hashcode值),根据散列值求出对象在哈希表的存储位置,相同位置上的多个数据以链表方式连接,每次先加入的对象放进链表头。

示例代码:
Java代码
publicstaticvoidmain(String[] args){
Map<Integer, String>maps=newHashMap<Integer, String>();
maps.put(1,"小黑");
maps.put(2,"小白");
maps.put(null,null);
maps.put(10, "老王");
System.out.println("size: "+maps.size());
//根据key获取对象值
System.out.println(maps.get(10));
//是否存在此键
System.out.println(maps.containsKey(2));
//是否存在此值
System.out.println(maps.containsValue(null));
//遍历
Set<Entry<Integer,String>>entry=maps.entrySet();
Iterator<Entry<Integer,String>>iter=entry.iterator();
while(iter.hasNext())
{
System.out.println(iter.next());
}
//清除map
maps.clear();
}
HashMap是线程不安全的,非同步的,当需要重新散列时,数组扩大为原来的两倍,将会把所有数据重新进行插入,此时可能会破换原来的顺序,所有HashMap不能保证映射顺序。HaspMap的重新散列会影响性能。
2)Hashtable
此类实现了哈希表,该哈希表将键映射到相对应的值。任何非null都可以用作键或值,为了成功的在哈希表中存储和获取对象,用作键的对象必须实现hashCode方法和equals方法。
用法基本和HashMap相同,不过多介绍
HashMap和Hashtable的区别
1.HashMap可以使用null作为键或值,Hashtable不可以
2.HashMap是非同步的,线程不安全,而Hashtable是同步的,线程安全
3.Hashtable的默认容量为11,而HashM的默认容量为16。
3)TreeMap
基于红黑树显示的,该映射根据其键的自然排序进行排序,或者根据创建映射时提供的Comparator进行排序。所以,TreeMap使用自定义类作为key时要实现Comparable接口。
如:
自定义Person类,实现Comparable接口。使用age属性进行排序
Java代码
publicclassPerson implementsComparable<Person>{
publicString name;
publicintage;
publicPerson(String name,intage)
{
this.name=name;
this.age=age;
}
publicintcompareTo(Person o) {
if(o==null)
thrownewNullPointerException();
if(this.age>o.age)
return1;
if(this.age<o.age)
return-1;
return0;
}
@Override
publicString toString() {
return"Person [name="+ name + ", age="+ age + "]";
}
}
调用代码:
Java代码
publicstaticvoidmain(String[] args){
Map<Integer, String>maps=newTreeMap<Integer, String>();
maps.put(1,"小黑");
maps.put(2,"小白");
maps.put(10, "老王");
//遍历
Set<Entry<Integer,String>>entry=maps.entrySet();
Iterator<Entry<Integer,String>>iter=entry.iterator();
while(iter.hasNext())
{
System.out.println(iter.next());
}
//清除map
maps.clear();
//-----------------------------使用自定义Person做key
Map<Person, String>map=newTreeMap<Person, String>();
map.put(newPerson("xiaobai", 20), "xiaobai");
map.put(newPerson("xiaohei", 18), "xiaohei");
map.put(newPerson("xiaohong", 30), "xiaohong");
//遍历
Set<Entry<Person,String>>entry1=map.entrySet();
Iterator<Entry<Person,String>>iter1=entry1.iterator();
while(iter1.hasNext())
{
System.out.println(iter1.next());
}
//清除map
map.clear();
}
运行结果:

技术分享:www.kaige123.com
Java集合之Map接口的更多相关文章
- Java集合框架Map接口
集合框架Map接口 Map接口: 键值对存储一组对象 key不能重复(唯一),value可以重复 常用具体实现类:HashMap.LinkedHashMap.TreeMap.Hashtable Has ...
- Java集合中Map接口的使用方法
Map接口 Map提供了一种映射关系,其中的元素是以键值对(key-value)的形式存储的,能够实现根据key快速查找value: Map中的键值对以Entry类型的对象实例形式存在: 建(key值 ...
- Java集合框架——Map接口
第三阶段 JAVA常见对象的学习 集合框架--Map集合 在实际需求中,我们常常会遇到这样的问题,在诸多的数据中,通过其编号来寻找某一些信息,从而进行查看或者修改,例如通过学号查询学生信息.今天我们所 ...
- JAVA集合框架 - Map接口
Map 接口大致说明(jdk11): 整体介绍: 一个将键映射到值的(key-value)对象, 键值(key)不能重复, 每个键值只能影射一个对象(一一对应). 这个接口取代了Dictionary类 ...
- Java:集合,Map接口框架图
Java集合大致可分为Set.List和Map三种体系,其中Set代表无序.不可重复的集合:List代表有序.重复的集合:而Map则代表具有映射关系的集合.Java 5之后,增加了Queue体系集合, ...
- Java集合——集合框架Map接口
1.Map接口 public interface Map<K,V>将键映射到值的对象.一个映射不能包含重复的键:每个键最多只能映射到一个值. 2.HashMap.Hashtable.Tr ...
- java集合 之 Map集合
Map用于保存具有映射关系的数据,具有两组值:一组用于保存Map中的key:另一组用于保存Map中的value,形成key-value的存储形式. Map集合中包含的一些方法: void clear( ...
- Java集合之Collection接口
java的集合分为三大接口,分别是Collection,Map,Iterator,集合接口和类在java.util包中,此次主要介绍三大接口之一的Collection接口. 一些Collection允 ...
- java 集合(Map)
-------------------|Map 储存的数据都是以键值对的形式,键不可重复,值可重复. ----------------------------| HashMap ---------- ...
随机推荐
- [Android Pro] android 混淆文件project.properties和proguard-project.txt
参考文档:http://blog.csdn.net/xueyepiaoling/article/details/8202359转载自:http://glblong.blog.51cto.com/305 ...
- myeclipse2013和以后版本破解
当你下到最新版的myeclipse-blue的时候你是否会为注册激活而烦恼呢,别担心,其实激活也就那么点事儿,请遵循我如下做法就可以了: 1.运行jdk下面的cracker.jar文件来打开生成活跃码 ...
- Java并发编程:Synchronized及其实现原理
Java并发编程系列: Java 并发编程:核心理论 Java并发编程:Synchronized及其实现原理 Java并发编程:Synchronized底层优化(轻量级锁.偏向锁) Java 并发编程 ...
- 用java程序打印菱形
代码如下
- 创建型模式之Singleton模式
单例模式大概是最直观的一种设计模式了,尽管直观却不简单. 数学与逻辑学中,singleton定义为“有且仅有一个元素的集合”, 单例模式可以如下定义:“一个类有且仅有一个实例,并且自行实例化向整个系统 ...
- Android VLC播放器二次开发1——程序结构分析
最近因为一个新项目需要一个多媒体播放器,所以需要做个视频.音频.图片方面的播放器.也查阅了不少这方面的资料,如果要从头做一个播放器工作量太大了,而且难度也很大.所以最后选择了VLC作为基础,进行二次开 ...
- Java Hour 23 Networking
有句名言,叫做10000小时成为某一个领域的专家.姑且不辩论这句话是否正确,让我们到达10000小时的时候再回头来看吧. 首先拟好主题,做到心中有数,再去写内容. socket public stat ...
- struts2的标签中得到JSP脚本的变量值
转自:http://www.cnblogs.com/modou/articles/1299024.html 大家先来看一段代码: <% int i=1; %> <s:property ...
- Java运算符优先级(转)
转自:http://www.cnblogs.com/gw811/archive/2012/10/13/2722752.html Java运算符优先级 序列号 符号 名称 结合性(与操作数) 目数 说明 ...
- Searchable(搜索功能)(转)
文章来源:http://developer.android.com/guide/topics/search/search-dialog.html 一.前言: Android为程序的搜索功能提供了统一的 ...