`
jiauwu
  • 浏览: 83665 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论
阅读更多

Map 键值对,数据结构测试代码如下

MapTest

package ds.collections.maps;

import java.util.Collections;
import java.util.Map;
import java.util.TreeMap;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map.Entry;
import java.util.LinkedHashMap;

/**
 * Map 
 * @author Hust
 * @Time 2011-10-23
 */
public class MapTest {

	public static void main(String[] args) {
		//testHashMap();
		//hashMapTest();
		//treeMapTest();
		linkedHashMapTest();
	}
	
	/**
	 * 测试HashMap
	 */
	public static void testHashMap(){
		//无序,hashMap本身的实现不是同步的即不是线程安全的
		//如想设为线程安全,初始化时加上:Collections.synchronizedMap
		Map<Integer,String> thMap = Collections.synchronizedMap(new HashMap<Integer, String>(32));
		thMap.put(1232, "12323321");
		thMap.put(1, "1233421");
		thMap.put(4, "12323321");
		thMap.put(123, "23455");
		//System.out.println(thMap.hashCode()+"_"+thMap.size());
		//thMap.remove(123);
		thMap.put(123, "234");
		thMap.put(null, "234");
		//System.out.println(thMap.size());
		//System.out.println(thMap.isEmpty());
		//System.out.println(thMap.containsKey(123));
		//System.out.println(thMap.containsValue("123321"));
		//System.out.println(thMap.get(123));
		//System.out.println(thMap.values());	
		for(Entry<Integer,String> b : thMap.entrySet()) {
		       System.out.print(b.getKey()+"_");//获取键  
		       System.out.println(b.getValue());//获取值  
		} 
		//thMap.clear();
		System.out.println("=thMap.size() "+thMap.size());
		//Map.Entry--Map的内部类,描述Map中的按键/数值对。   
		Map<Integer,String> linkMap = new LinkedHashMap<Integer, String>(thMap);
		
		 for(Entry<Integer,String> b : linkMap.entrySet()) {
		       System.out.print(b.getKey()+"_");//获取键  
		       System.out.println(b.getValue());//获取值  
		} 
		
	}
	
	/**
	 * 无序  适合 插入、删除和定位元素容量小时具有很快的访问速度
	 * 容量很大,实际数据较少时,遍历起来可能会比LinkedHashMap慢
	 */
    public static void hashMapTest() {  
        System.out.println("------hashMapTest------");  
        Map<String,String> map = new HashMap<String,String>();  
        map.put("1", "Value 1");  
        map.put("2", "Value 2");  
        map.put("3", "Value 3");  
        map.put("4", "Value 4");  
        map.put("F", "Value F");  
        map.put("Q", "Value Q");  
        
        //必要时初始化时控制Map大小
        //其负载因子默认为0.75,容量(大小)默认为16, 如果(负载因子)*(容量)〉map大小,则调整Map大小
        //8 * 0.75 = 6
        Map<String,String> map2 = new HashMap<String,String>(8);  
        map2.putAll(map);
        
        //可对之进行迭代,Entry,Map的内部类,描述Map中的按键/数值对。
        //Map.entrySet返回map的collection视图
        Iterator<Entry<String, String>> it = map2.entrySet().iterator();  
        while (it.hasNext()) {  
            Map.Entry<String,String> e = (Map.Entry<String,String>) it.next();  
            System.out.println(e.getKey() + " _ " + e.getValue());  
        }  
    }  
    
    /**
     * TreeMap取出来的是排序后的键值对。
     * 它是sortedMap的唯一实现
     */
    public static void treeMapTest() {  
        System.out.println("------treeMapTest------");  
        Map<String,String> map = new TreeMap<String,String>();  
        map.put("1", "Value 1");  
        map.put("F", "Value F");  
        map.put("Q", "Value Q"); 
        map.put("3", "Value 2");  
        map.put("5", "Value 5");  
        map.put("4", "Value 4");   
        
        Iterator<Entry<String, String>> it = map.entrySet().iterator();   
        while (it.hasNext()) {  
            Map.Entry<String,String> e = (Map.Entry<String,String>) it.next();  
            System.out.println(e.getKey() + " _ " + e.getValue());  
        }  

        System.out.println("------treeMapTest2------");  
        //TreeMap取出来的是排序后的键值对。它是sortedMap的唯一实现。
        //默认按键对象升序排列,如想降序排列,实现方式为将Collections.reverseOrder()作为TreeMap的构造方法。
        Map<String,String> tmap = new TreeMap<String,String>(Collections.reverseOrder());
        tmap.putAll(map);
        Iterator<Entry<String, String>> tmapit = tmap.entrySet().iterator();   
        while (tmapit.hasNext()) {  
            Map.Entry<String,String> e = (Map.Entry<String,String>) tmapit.next();  
            System.out.println( e.getKey() + " _ " + e.getValue());  
        }  
        
    } 
	
    /**
     * 保存了记录的插入顺序,即先插入的先遍历到
     * 也可以在构造时用带参数,按照应用次数排序。
     */
    public static void linkedHashMapTest() {  
    	System.out.println("------linkedHashMapTest------");  
    	Map<String,String> map = new LinkedHashMap<String,String>();  
    	map.put("1", "Value 1");  
    	map.put("2", "Value 2");  
    	map.put("5", "Value 3");  
    	map.put("4", "Value 4");  
    	map.put("F", "Value F");  
    	map.put("Q", "Value Q");  
        Iterator<Entry<String, String>> it = map.entrySet().iterator();  
    	while (it.hasNext()) {  
    		Map.Entry<String,String> e = (Map.Entry<String,String>) it.next();  
    		System.out.println(e.getKey() + " _ " + e.getValue());  
    	}  
    } 
    
}
 


分享到:
评论
1 楼 jiauwu 2011-11-07  
补充:
/**
 * 对Map的值集与键集的遍历
 */
public static void keyValueSet(){
	Map<Integer,String> thMap = new HashMap<Integer, String>(32);
	thMap.put(1232, "12323321");
	thMap.put(1, "1233421");
	thMap.put(4, "12323321");
	//value
	Iterator<String> it = (Iterator<String>) thMap.values().iterator();
	while (it.hasNext()) {
		System.out.println(it.next());
	}
	//key
	Iterator<Integer> itk = (Iterator<Integer>) thMap.keySet().iterator();
	while (itk.hasNext()) {
		System.out.println(itk.next());
	}
	
}

相关推荐

    java map 实现缓存技术

    在Java编程中,Map接口是数据结构中非常重要的一个部分,它提供了键值对的存储方式,便于快速访问和操作数据。在许多实际应用中,尤其是高性能和高并发的场景,Map常被用来实现缓存技术,以提高数据读取速度和系统...

    java Map 遍历方法

    ### Java Map遍历方法详解 在Java编程语言中,`Map`接口是集合框架中的一个核心组成部分,它存储键值对映射。本篇文章将详细介绍几种常用的遍历`Map`的方法,包括使用传统迭代器(Iterator)、增强型for循环(For-...

    Java Map按键排序和按值排序

    Java Map按键排序和按值排序 Java Map按键排序和按值排序是Java编程语言中常用的数据结构之一。Map是一种键值对的集合,它可以按照键或值进行排序。下面,我们将详细地介绍Java Map的按键排序和按值排序。 按键...

    Java Map 集合类简介

    【Java Map 集合类简介】 在Java的`java.util`包中,集合类扮演着重要的角色,其中List和Map是最为常见的两种。List的实现例如ArrayList和Vector,它们都是可变大小的列表,适合存储和操作各种类型对象的序列。特别...

    java Map 转为 Obj Obj 转为 Map

    java Map 转为 Obj Obj 转为 Map

    JavaMap.rar_arraylist map_collection_java map_javamap_地图 java

    在Java中,"javamap"和"地图_java"可能是指使用Map类来模拟现实世界中的地理地图,例如通过键表示地理位置,值表示该地点的信息。这涉及到自定义类作为键值对中的元素类型,以及如何设计键值对以适应特定需求的问题...

    java Map

    是java Map中几种常用的遍历方法,适合于新手,谢谢

    12.javaMap 接口及其实现类.zip

    12.javaMap 接口及其实现类.zip12.javaMap 接口及其实现类.zip12.javaMap 接口及其实现类.zip12.javaMap 接口及其实现类.zip12.javaMap 接口及其实现类.zip12.javaMap 接口及其实现类.zip12.javaMap 接口及其实现类....

    Java Map 遍历比较齐全的解析.docx

    在Java编程中,`Map`接口是集合框架的一部分,它提供了键值对的存储功能。在处理`Map`对象时,我们经常需要遍历其中的所有元素。本篇将详细介绍Java中遍历`Map`的不同方法,以及如何获取`Map`的长度。 1. **遍历Map...

    map(java).rar_ map ja_MAP JAVA_java map_java系统_map

    标题中的"map(java).rar_ map ja_MAP JAVA_java map_java系统_map"暗示了这是一个与Java编程语言相关的项目,特别是涉及到地图(Map)的实现。在Java中,`Map`是一个接口,它定义了键值对的数据结构,允许我们通过键...

    13.javaMap接口的两个实现类:.zip

    13.javaMap接口的两个实现类:.zip13.javaMap接口的两个实现类:.zip13.javaMap接口的两个实现类:.zip13.javaMap接口的两个实现类:.zip13.javaMap接口的两个实现类:.zip13.javaMap接口的两个实现类:.zip13.java...

    java map转实体

    java map转实体可以利用java的反射去封装,于是就在hibernate的工具类下试着封装了下,封装完了之后感觉没必要,这完全就可以提取出来变成一个独立的工具类,而不仅仅局限于hibernate了,这样既可以满足一个hql查询...

    java一键xml转map,一键map转xml工具类

    在Java编程中,XML(可扩展标记语言)和Map(映射)是两种常见的数据存储和交换格式。XML因其结构化和易于解析的特性,在数据交换和配置文件中广泛使用,而Map则作为Java中存储键值对的高效数据结构。在实际开发中,...

    java Map转换成bean,利用java反射以及java和bean包

    总之,Java Map到Bean的转换是通过反射和JavaBeans规范实现的,这是Java开发中常用的一种数据转换技巧。理解并熟练运用这些知识,能够帮助我们更高效地处理各种数据结构,提升代码的灵活性。在实际项目中,可以根据...

    Java Map 按值排序

    在Java编程语言中,Map接口提供了键值对的存储方式,但默认情况下,Map并不会按照特定的顺序来存储或返回元素。然而,在某些场景下,我们可能需要将Map中的元素按照值(value)进行排序。本文将详细介绍如何在Java中...

    java Map遍历方法

    在Java编程语言中,`Map`接口是集合框架的一个重要组成部分,它提供了键值对(key-value pairs)的存储和访问。这篇博文主要探讨了如何遍历Java中的`Map`对象,下面将详细介绍几种常见的遍历`Map`的方法。 1. **...

    java循环Map java迭代Map

    Map a = new HashMap(); //方法一 Iterator it = a.entrySet().iterator(); while (it.hasNext()) { Map.Entry pairs = (Map.Entry) it.next(); System.out.println(pairs.getValue()); } //以下方法需要jdk5以上...

    java map 集合 排序

    在Java编程语言中,Map集合是一个非常重要的数据结构,它存储键值对,其中每个键都是唯一的。然而,Map默认不保证元素的顺序,如果需要按照特定规则进行排序,我们需要用到特定类型的Map或者手动排序。本文将深入...

    Java Map 遍历实例与效率比较

    主要提供java中的map的遍历实例及效率比较

    美国的邮政编码 全部 java map

    在这个场景中,我们有一个关于美国邮政编码的Java程序,它利用Map数据结构来高效地管理这些信息。本文将深入探讨这个程序背后的技术细节。 首先,让我们关注标题“美国的邮政编码 全部 java map”。这表明该程序的...

Global site tag (gtag.js) - Google Analytics