00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)

系列文章目录

文章目录

  • 系列文章目录
  • 前言
  • 一、Map接口的实现类们:
  • 二、HashMap和Hashtable 哈希表
  • 三、HashMap和LinkedHashMap
  • 四、HashMap和TreeMap
  • 五、Properties
    • 六、所有的map的key不能重复,如何实现不重复?
    • 七、、完整代码

前言

这一节讲它的实现类

一、Map接口的实现类们:

1、HashMap
2、Hashtable
3、TreeMap
4、LinkedHashMap
5、Properties

二、HashMap和Hashtable 哈希表

Hashtable:旧版。线程安全的。它的key和value不能为null。
HashMap:相对Hashtable它来说新一点。线程不安全。它允许key和value为null值。
并且他们排序也稍有不同
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第1张图片
关联记忆:(旧的写前面)
StringBuffer和StringBuilder
Vector和ArrayList
Hashtable和HashMap

三、HashMap和LinkedHashMap

LinkedHashMap是HashMap的子类,比HashMap多维护了映射关系的添加顺序。
HashMap:无序的
LinkedHashMap:可以记录添加顺序。
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第2张图片
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第3张图片

LinkedHashMap比HashMap要做的事多,效率低。所以建议我们只在需要维护顺序时再使用它。

四、HashMap和TreeMap

HashMap:无序的。
TreeMap:按照key排大小顺序。

五、Properties

Properties是Hashtable的子类,不允许key和value是null,并且它的key和value的类型都是String。
通常用于存储配置属性。
而且为了可读性更好,还增加了两个方法:
setProperty(key,value)
String getProperty(key)
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第4张图片
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第5张图片
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第6张图片
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第7张图片

00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第8张图片
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第9张图片
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第10张图片
注意上面红框标错了,是System.getProperties()
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第11张图片
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第12张图片

六、所有的map的key不能重复,如何实现不重复?

HashMap、Hashtable、LinkedHashMap、Properties:依据key的hashCode和equals方法
TreeMap:依据key的大小,认为大小相等的两个key就是重复的
如果key重复了,那么后面的value会替换原来的value。
TreeMap要让key排大小,要么key类型本身实现了java.lang.Comparable接口,要么在创建TreeMap时,指定一个java.util.Comparator接口的实现类对象。
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第13张图片
00020.07 集合Map的接口和它的实现类们(包含HashMap、Hashtable、TreeMap、LinkedHashMapProperties以及实现Comparable接口模板)_第14张图片

七、、完整代码

package com.atguigu.test06;

import java.io.IOException;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Properties;
import java.util.Set;
import java.util.TreeMap;

import org.junit.Test;

@SuppressWarnings("all")
public class TestMapImpl {
     
	
	//key不可重复
	@Test
	public void test7(){
     
		Map map = new HashMap();
		
		map.put("杨洪强", "翠花");//被覆盖了
		map.put("崔志恒", "如花");
		map.put("甄玉禄", "凤姐");
		map.put("杨洪强", "冰冰");
		
		Set entrySet = map.entrySet();
		for (Object entry : entrySet) {
     
			System.out.println(entry);
		}
	}
	
	
	@Test
	public void test6() throws IOException{
     
		Properties pro = System.getProperties();//获取系统属性配置
		Set entrySet = pro.entrySet();
		for (Object entry : entrySet) {
     
			System.out.println(entry);
		}
	}
	
	@Test
	public void test5() throws IOException{
     
		Properties pro = new Properties();
		pro.load(TestMapImpl.class.getClassLoader().getResourceAsStream("jdbc.properties"));
		
		String user = pro.getProperty("user");
		String password = pro.getProperty("password");
		System.out.println(user);
		System.out.println(password);
	}
	
	@Test
	public void test4(){
     
		Properties pro = new Properties();
		pro.setProperty("user", "chailinyan");
		pro.setProperty("pwd", "123456");
		
		String user = pro.getProperty("user");
		String password = pro.getProperty("pwd");
		System.out.println(user);
		System.out.println(password);
	}
	
	@Test
	public void test3(){
     
		Map map = new TreeMap();//按照key排大小顺序。
		
		map.put("yanghongqiang", "翠花");
		map.put("cuizhiheng", "如花");
		map.put("zhenyulu", "凤姐");
		map.put("suhaibo", "翠花");
		
		Set entrySet = map.entrySet();
		for (Object entry : entrySet) {
     
			System.out.println(entry);
		}
	}
	
	@Test
	public void test2(){
     
		Map map = new LinkedHashMap();//按照添加顺序
		
		map.put("杨洪强", "翠花");
		map.put("崔志恒", "如花");
		map.put("甄玉禄", "凤姐");
		map.put("苏海波", "翠花");
		
		Set entrySet = map.entrySet();
		for (Object entry : entrySet) {
     
			System.out.println(entry);
		}
	}
	
	@Test
	public void test1(){
     
		Map map = new HashMap();//完全无序
		
		map.put("杨洪强", "翠花");
		map.put("崔志恒", "如花");
		map.put("甄玉禄", "凤姐");
		map.put("苏海波", "翠花");
		
		Set entrySet = map.entrySet();
		for (Object entry : entrySet) {
     
			System.out.println(entry);
		}
	}
}

你可能感兴趣的:(javaSE,Map,集合)