Hashtable、HashMap 、Properties的创建,使用,遍历

Map映射

-两个集合之间的元素对应关系
-一个输入对应到一个输出
-{1,张三}, {2,李四}, {Key, Value},键值对, K-V对

Java中Map

-Hashtable (同步,慢, 数据量小)
-HashMap (不支持同步,快,数据量大)
-Properties (同步,文件形式,数据量小)

Hashtable

-K-V对,K和V都不允许为null
-同步,多线程安全
-无序的
-适合小数据量
-主要方法: clear清空数据,contains等同containsValue是否包含某一个值,containsKey是否包含某一个Key,get根据Key获取相应的值,put增加新的K-V对,remove删除某一个K-V对,size返回数据大小

创建
import java.util.Enumeration;
import java.util.Hashtable;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;

public class HashtableTest {
	public static void main(String[] args) {
		Hashtable<Integer,String> ht =new  Hashtable<Integer,String>();
		//ht.put(1, null); 编译不报错  运行报错
		//ht.put(null,1);  编译报错
		ht.put(1000, "aaa");
		ht.put(2, "bbb");
		ht.put(30000, "ccc");
		System.out.println(ht.contains("aaa"));
		System.out.println(ht.containsValue("aaa"));
		System.out.println(ht.containsKey(30000));
		System.out.println(ht.get(30000));
		
		ht.put(30000, "ddd");  //更新覆盖ccc
		ht.remove(2);	
		ht.clear();
遍历方法

创建Hashtable

		Hashtable<Integer,String> ht2 =new  Hashtable<Integer,String>();
		for(int i=0;i<100000;i++)
		{
			ht2.put(i, "aaa");
		}
		traverseByEntry(ht2);    //Entry迭代器遍历
		traverseByKeySet(ht2);   //KeySet迭代器遍历
		traverseByKeyEnumeration(ht2);		//KeyEnumeration迭代器遍历
	}

Entry迭代器遍历,Entry是指整个K-V对

	public static void traverseByEntry(Hashtable<Integer,String> ht)
	{
		Integer key;
		String value;
		Iterator<Entry<Integer, String>> iter = ht.entrySet().iterator();
		while(iter.hasNext()) 
		{
		    Map.Entry<Integer, String> entry = iter.next();
		    // 获取key
		    key = entry.getKey();
		    // 获取value
		    value = entry.getValue();
		}
	}
	

Key的iterator迭代器遍历,可以删除元素

	public static void traverseByKeySet(Hashtable<Integer,String> ht)
	{
		Integer key;
		String value;
		Iterator<Integer> iter = ht.keySet().iterator();
		while(iter.hasNext()) 
		{
		    key = iter.next();		    
		    // 获取value
		    value = ht.get(key);
		}
	}

Key的Enumeration迭代器遍历,只读

	public static void traverseByKeyEnumeration(Hashtable<Integer,String> ht)
	{
		Integer key;
		String value;
		Enumeration<Integer> keys = ht.keys();
		while(keys.hasMoreElements()) 
		{
		    key = keys.nextElement();   
		    // 获取value
		    value = ht.get(key);
		}
	}

Entry遍历最慢,Enumeration最快

HashMap

-K-V对, K和V都允许为null
-不同步,多线程不安全
-无序的
-主要方法: clear, containsValue, containsKey, get, put,remove, size

创建
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;

public class HashMapTest {
	public static void main(String[] args) {
		HashMap<Integer,String> hm =new  HashMap<Integer,String>();
		hm.put(1, null); 
		hm.put(null, "abc");  
		hm.put(1000, "aaa");
		hm.put(2, "bbb");
		hm.put(30000, "ccc");
		hm.containsValue("aaa");
		hm.containsKey(30000);
		hm.get(30000);
		hm.put(30000, "ddd");  //更新覆盖ccc
		hm.remove(2);
		hm.clear();
遍历方法

创建HashMap

		HashMap<Integer,String> hm2 =new  HashMap<Integer,String>();
		for(int i=0;i<100000;i++)
		{
			hm2.put(i, "aaa");
		}
		traverseByEntry(hm2);  //Entry迭代器遍历
		traverseByKeySet(hm2);		//KeySet迭代器遍历
	}

Entry迭代器遍历

	public static void traverseByEntry(HashMap<Integer,String> ht)
	{
		Integer key;
		String value;
		Iterator<Entry<Integer, String>> iter = ht.entrySet().iterator();
		while(iter.hasNext()) 
		{
		    Map.Entry<Integer, String> entry = iter.next();
		    // 获取key
		    key = entry.getKey();
		    // 获取value
		    value = entry.getValue();
		}
	}

KeySet迭代器遍历

	public static void traverseByKeySet(HashMap<Integer,String> ht)
	{
		Integer key;
		String value;
		Iterator<Integer> iter = ht.keySet().iterator();
		while(iter.hasNext()) 
		{
		    key = iter.next();		    
		    // 获取value
		    value = ht.get(key);
		}
	}

LinkedHashMap

-基于双向链表的维持插入顺序的HashMap TreeMap

创建
import java.util.LinkedHashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;

public class LinkedHashMapTest {
	public static void main(String[] args) {
		LinkedHashMap<Integer,String> hm=new LinkedHashMap<Integer,String>();
		hm.put(1, null); 
		hm.put(null, "abc");  
		hm.put(1000, "aaa");
		hm.put(2, "bbb");
		hm.put(30000, "ccc");
		hm.containsValue("aaa");
		hm.containsKey(30000);
		hm.get(30000);
		hm.put(30000, "ddd");  //更新覆盖ccc
		hm.remove(2);
		hm.clear();
遍历方法

创建LinkedHashMap

	LinkedHashMap<Integer,String> hm2=new LinkedHashMap<Integer,String>();
	for(int i=0;i<100000;i++)
	{
		hm2.put(i, "aaa");
	}
	traverseByEntry(hm2);   //Entry迭代器遍历
	traverseByKeySet(hm2);		//KeySet迭代器遍历
}

Entry迭代器遍历

	public static void traverseByEntry(LinkedHashMap<Integer,String> ht)
	{
		Integer key;
		String value;
		Iterator<Entry<Integer, String>> iter = ht.entrySet().iterator();
		while(iter.hasNext()) 
		{
		    Map.Entry<Integer, String> entry = iter.next();
		    // 获取key
		    key = entry.getKey();
		    // 获取value
		    value = entry.getValue();
		}
	 }

KeySet迭代器遍历

	
	public static void traverseByKeySet(LinkedHashMap<Integer,String> ht)
	{
		Integer key;
		String value;
		Iterator<Integer> iter = ht.keySet().iterator();
		while(iter.hasNext()) 
		{
		    key = iter.next();		    
		    // 获取value
		    value = ht.get(key);
		    //System.out.println("Key:" + key + ", Value:" + value);
		}
	}
}

TreeMap

-基于红黑树的Map,可以根据key的自然排序或者compareTo方法进行排序输出

创建
import java.util.TreeMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;

public class TreeMapTest {
	public static void main(String[] args) {
		TreeMap<Integer,String> hm =new  TreeMap<Integer,String>();
		hm.put(1, null); 
		//hm.put(null, "abc");  编译没错,运行报空指针异常  
		hm.put(1000, "aaa");
		hm.put(2, "bbb");
		hm.put(30000, "ccc");
		hm.containsValue("aaa");
		hm.containsKey(30000);
		hm.get(30000);
		hm.put(30000, "ddd");  //更新覆盖ccc
		hm.remove(2);
		hm.clear();
遍历方法

创建TreeMap

		TreeMap<Integer,String> hm2 =new  TreeMap<Integer,String>();
		for(int i=0;i<100000;i++)
		{
			hm2.put(i, "aaa");
		}
		traverseByEntry(hm2);    //Entry迭代器遍历
		traverseByKeySet(hm2);	//KeySet迭代器遍历
	}	

Entry迭代器遍历

	public static void traverseByEntry(TreeMap<Integer,String> ht)
	{
		Integer key;
		String value;
		Iterator<Entry<Integer, String>> iter = ht.entrySet().iterator();
		while(iter.hasNext()) 
		{
		    Map.Entry<Integer, String> entry = iter.next();
		    // 获取key
		    key = entry.getKey();
		    // 获取value
		    value = entry.getValue();
		}
	}

KeySet迭代器遍历

	public static void traverseByKeySet(TreeMap<Integer,String> ht)
	{
		Integer key;
		String value;
		Iterator<Integer> iter = ht.keySet().iterator();
		while(iter.hasNext()) 
		{
		    key = iter.next();		    
		    // 获取value
		    value = ht.get(key);
		    //System.out.println("Key:" + key + ", Value:" + value);
		}
	}
}

Properties

-继承于Hashtable
-可以将K-V对保存在文件中
-适用于数据量少的配置文件
-从文件加载的load方法, 写入到文件中的store方法
-获取某一个Key所对应的Value用getProperty,写入一个K-V对用setProperty
-如需要将 K-V 存储为文件,可采用 Properties 类

常规操作
import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.Enumeration;
import java.util.Properties;

//关于Properties类常用的操作
public class PropertiesTest {
    public static String GetValueByKey(String filePath, String key) {
        Properties pps = new Properties();
        try {
            InputStream in = new BufferedInputStream (new FileInputStream(filePath));  
            pps.load(in); //所有的K-V对都加载了
            String value = pps.getProperty(key);    //根据Key读取Value
            return value;     
        }catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }
写入
    //写入Properties信息
    public static void WriteProperties (String filePath, String pKey, String pValue) throws IOException {
        File file = new File(filePath);
    	if(!file.exists())
    	{
    		file.createNewFile();
    	}
    	Properties pps = new Properties();
        
        InputStream in = new FileInputStream(filePath);
        //从输入流中读取属性列表(键和元素对) 
        pps.load(in);
        //调用 Hashtable 的方法 put。使用 getProperty 方法提供并行性。  
        //强制要求为属性的键和值使用字符串。返回值是 Hashtable 调用 put 的结果。
        OutputStream out = new FileOutputStream(filePath);
        pps.setProperty(pKey, pValue);
        //以适合使用 load 方法加载到 Properties 表中的格式,  
        //将此 Properties 表中的属性列表(键和元素对)写入输出流  
        pps.store(out, "Update " + pKey + " name");
        out.close();
    }
读取
    //读取Properties的全部信息
    public static void GetAllProperties(String filePath) throws IOException {
        Properties pps = new Properties();
        InputStream in = new BufferedInputStream(new FileInputStream(filePath));
        pps.load(in); //所有的K-V对都加载了
        Enumeration en = pps.propertyNames(); //得到文件的名字
        
        while(en.hasMoreElements()) {
            String strKey = (String) en.nextElement();
            String strValue = pps.getProperty(strKey);
        }
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值