Map接口之HashMap,LinkedHashMap,TreeMap
Map与Collection 并列存在,用于保存具有映射关系的数据:Key-Value
Map中的Key和Value都可以是任何引用类型的数据
Map中的Key用Set存放,不允许重复,即同一个Map对象所对应的类,须重写HashCode()和equals()方法
常用String类作为Map的 "键"
Key和vlaue之间存在单项一对一关系,即通过指定的Key总能找到唯一的,确定的value
TestMap
package com.aff.coll; import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.Collection;
import java.util.Comparator;
import java.util.HashMap;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Properties;
import java.util.Set;
import java.util.TreeMap; import org.junit.Test; /*
Collection接口 Map接口
|----HashMap:Map的主要实现类
|----LinkedHashMap:使用链表维护添加进 Map 中的顺序.故遍历map时,是按添加的顺序遍历的
|----TreeMap: 按照添加进Map中的元素的 key 的指定属性进行排序,要求key必须是同一个类对象
自动排序 vs 定制排序
|----Hashtable :①古老的Map实现类,线程安全,不允许使用null作为key和value
②和HashMap一样不能保证其中key-value对的顺序
③判断两个key相等,两个value相等的标准和HashMap一致
④太古老,标识符的table还是小写的,不建议使用
|---- Properties :常用来处理属性文件。键和值都为String类型的
*/
public class TestMap {
//使用Properties处理属性文件
@Test
public void testProperties() throws FileNotFoundException, IOException{
Properties pros = new Properties();
pros.load(new FileInputStream(new File("jdbc.properties")));
String user = pros.getProperty("user");
System.out.println(user);//root;
String password = pros.getProperty("password");
System.out.println(password);//123ab;
} /* Map常用方法:
Object put(Objet key,Object value); 向Map中添加一个元素
Object remove(Object key); 按照指定的key删除此key-value
void putAll(Map t);
void clear(); 清空 Object get(Object key); 获取指定key的value值,若无此key,则返回null boolean ontainsKey(Object key);
boolean containsValue(Object value);
int size(); 返回集合的长度
boolean isEmpty();
boolean equals(Object obj);
*/ //HashMap
/*
1.HashMap :key使用Set来存放的,不可重复,Value是用collection来存放的,
可重复的一个key-value对,是一个Entry.所有的Entry是用Set存放的,也是不可重复的。
2.向HashMap中添加元素时,会调用key所在的类的equals()方法,判断两个key是否相同,
若相同,则只能添加进后添加的那个元素
*/
@Test
public void testHashMap() {
Map map = new HashMap();
map.put("AA", 12);
map.put("BB", 143);
map.put("BB", 4656);
map.put(123, "VV");
map.put(null, null);
System.out.println(map.size());//
} //遍历Map
@Test
public void testHashMap2() {
/*
如何遍历Map
Set KeySet();
Collection values();
Set entrySet();
*/
Map map = new HashMap();
map.put("AA", 12);
map.put("BB", 143);
map.put(123, "VV");
map.put(null, null);
map.put(new Person("DD", 23), 46); //1.遍历key集
Set set = map.keySet();
for(Object obj: set){
System.out.println(obj);
}
System.out.println("----");
//2.遍历value集
Collection values = map.values();
Iterator iterator = values.iterator();
while(iterator.hasNext()){
System.out.println(iterator.next());
}
//3.遍历key-value对
//方式一:
Set set1 = map.keySet();
for(Object obj : set1){
//Object get(Object key); 获取指定key的value值,若无此key,则返回null
System.out.println(obj+"----->"+map.get(obj));
}
System.out.println("------"); //方式二:
Set set2 = map.entrySet();
for(Object obj:set2){
Map.Entry entry = (Map.Entry)obj;
System.out.println(entry.getKey()+"---->"+entry.getValue());
}
} //LinkedHashMap 使用链表维护添加进 Map 中的顺序.故遍历map时,是按添加的顺序遍历的
@Test
public void testLinkedHashMap(){
Map map = new LinkedHashMap();
map.put("AA", 12);
map.put("BB", 143);
map.put(123, "VV");
map.put(null, null);
map.put(new Person("DD", 23), 46);
System.out.println(map);
} //TreeMap 的自然排序
@Test
public void testTreeMap(){
Map map = new TreeMap();
map.put(new Person("AA", 23), 46);
map.put(new Person("CC", 22), 68);
map.put(new Person("GGG", 33), 26);
map.put(new Person("BB", 14), 98);
map.put(new Person("CC", 14), 98);
// System.out.println(map); Set set1 = map.keySet();
for(Object obj : set1){
//Object get(Object key); 获取指定key的value值,若无此key,则返回null
System.out.println(obj+"----->"+map.get(obj));
}
} //TreeMap 的定制排序
@Test
public void testTreeMap2(){
Comparator com = new Comparator() {
@Override
public int compare(Object o1, Object o2) {
if(o1 instanceof Customer && o2 instanceof Customer){
Customer c1 = (Customer)o1;
Customer c2 = (Customer)o2;
int i = c1.getId().compareTo(c2.getId());
if(i == 0){
return c1.getName().compareTo(c2.getName());
}
return i;
}
return 0;
}
};
Map map = new TreeMap();
map.put(new Person("AA", 23), 46);
map.put(new Person("CC", 22), 68);
map.put(new Person("GGG", 33), 26);
map.put(new Person("BB", 14), 98);
map.put(new Person("CC", 14), 98);
// System.out.println(map); Set set1 = map.keySet();
for(Object obj : set1){
//Object get(Object key); 获取指定key的value值,若无此key,则返回null
System.out.println(obj+"----->"+map.get(obj));
}
}
}
jdbc.properties
user=root;
password=123ab;
Customer, Person与上篇相同
Map接口之HashMap,LinkedHashMap,TreeMap的更多相关文章
- Java中HashMap,LinkedHashMap,TreeMap的区别[转]
原文:http://blog.csdn.net/xiyuan1999/article/details/6198394 java为数据结构中的映射定义了一个接口java.util.Map;它有四个实现类 ...
- Java HashMap,LinkedHashMap,TreeMap
Java为数据结构中的映射定义了一个接口java.util.Map;它有四个实现类,分别是HashMap Hashtable LinkedHashMap 和TreeMapMap主要用于存储健值对,根据 ...
- Java从入门到放弃18---Map集合/HashMap/LinkedHashMap/TreeMap/集合嵌套/Collections工具类常用方法
Java从入门到放弃18—Map集合/HashMap/LinkedHashMap/TreeMap/集合嵌套/Collections工具类常用方法01 Map集合Map集合处理键值映射关系的数据为了方便 ...
- java中HashMap,LinkedHashMap,TreeMap,HashTable的区别
java为数据结构中的映射定义了一个接口java.util.Map;它有四个实现类,分别是HashMap Hashtable LinkedHashMap 和TreeMap Map主要用于存储健值对,根 ...
- HashMap,LinkedHashMap,TreeMap对比
共同点: HashMap,LinkedHashMap,TreeMap都属于Map:Map 主要用于存储键(key)值(value)对,根据键得到值,因此键不允许键重复,但允许值重复. 不同点: 1.H ...
- java HashMap,LinkedHashMap,TreeMap应用
共同点: HashMap,LinkedHashMap,TreeMap都属于Map:Map 主要用于存储键(key)值(value)对,根据键得到值,因此键不允许键重复,但允许值重复. 不同点: 1.H ...
- Java集合(十)实现Map接口的HashMap
Java集合(十)继承Map接口的HashMap 一.HashMap简介(基于JDK1.8) HashMap是基于哈希表(散列表),实现Map接口的双列集合,数据结构是“链表散列”,也就是数组+链表 ...
- map,set,list等集合解析以及HashMap,LinkedHashMap,TreeMap等该选谁的的区别
前言: 今天在整理一些资料时,想起了map,set,list等集合,于是就做些笔记,提供给大家学习参考以及自己日后回顾. Map主要用于存储健值对,根据键得到值,因此不允许键重复(重复了覆盖了),但允 ...
- Map接口,Map.Entry,hashMap类,TreeMap类,WeakHashMap。
Collection接口之前接触过,每次保存的对象是一个对象,但是在map中保存的是一对对象,是以key->value形式保存的. 定义: public interface Map<K,V ...
随机推荐
- Python+wxpy 实现微信消息轰炸
需要导入wxpy,在终端中输入以下命令即可 pip install wxpy 如果没有pip先安装pip,安装好了的直接输入命令即可,安装好了但是显示没有安装的可能是没有将pip添加到PATH中,需要 ...
- 用纯css、JavaScript、jQuery简单的轮播图
完成一个可以自动切换或点击数字的轮播图 HTML代码只需要一个div 包含着一个图片和一个列表,我们主要的思路就是通过点击相应的数字,改变图片的 路径. 有4张图片都在img文件夹里,名称为 img ...
- spring类型转换
如果表单提交的时候,有的字段是字符串类型,但是后台接收到的时候是其他类型(比如日期类型),我们就可以使用类型转换来把字符串类型转换为需要的类型.当字符串类型和后台的日期类型匹配的时候,也可以不做转换, ...
- mybatis添加信息自动生成主键
一.使用Oracle数据库 举例:添加员工的时候自动生成主键 1.在dao接口中声明方法 2.在mapper中实现该方法 需要先在数据表中创建序列 3.测试 注意:在调用过save方法之后,emp对象 ...
- 【漫画】JAVA并发编程 J.U.C Lock包之ReentrantLock互斥锁
在如何解决原子性问题的最后,我们卖了个关子,互斥锁不仅仅只有synchronized关键字,还可以用什么来实现呢? J.U.C包中还提供了一个叫做Locks的包,我好歹英语过了四级,听名字我就能马上大 ...
- [hdu5226]组合数求和取模(Lucas定理)
题意:给一个矩阵a,a[i][j] = C[i][j](i>=j) or 0(i < j),求(x1,y1),(x2,y2)这个子矩阵里面的所有数的和. 思路:首先问题可以转化为求(0,0 ...
- pthon-安装新版PyQt5、PyQT5-tool后打不开并Designer.exe提示“This application failed to start because no Qt platform plugin could be initialized.Reinstalling the application the application may fix this program”
最近学习python,安装网上教程一步一步的安装,网上很多帖子都写的非常详细,不由深深感慨多谢各位不辞辛苦的记录,指导着来自新入门的同学. 但是实际安装中,最理想莫过于一次性安装成功,但自己安装就出现 ...
- Qt标准对话框按钮文字等设置为中文
问题描述:QMessageBox.QColorDialog等标准对话框按钮显示都是英文 设置中文方法如下: 1)拷贝Qt安装目录下的qt_zh_CN.qm和qt_zh_CN.ts文件到工程目录中 2) ...
- 曾经你说chrome浏览器天下第一,现在你却说Microsoft edge真香!呸,渣男!!
曾经你说chrome浏览器天下第一,现在你却说Microsoft edge真香!呸,渣男!! 一个月前我每天打卡搜索的时候,老是有微软新版浏览器的广告.我刚才是内心其实是抵触的,直到我发现了它的奇妙之 ...
- Android fragment 使用replace并保存状态
Fragment的地位在开发中可是举足轻重的,掌握它的的生命周期以及使用特性是非常重要的,例如在开发中常使用的模板: 点击菜单,中心内容跟随菜单变化,但是在菜单间切换时,需要保存之前输入的信息或其他状 ...