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());
}
}
}
分享到:
相关推荐
在Java编程中,Map接口是数据结构中非常重要的一个部分,它提供了键值对的存储方式,便于快速访问和操作数据。在许多实际应用中,尤其是高性能和高并发的场景,Map常被用来实现缓存技术,以提高数据读取速度和系统...
### Java Map遍历方法详解 在Java编程语言中,`Map`接口是集合框架中的一个核心组成部分,它存储键值对映射。本篇文章将详细介绍几种常用的遍历`Map`的方法,包括使用传统迭代器(Iterator)、增强型for循环(For-...
Java Map按键排序和按值排序 Java Map按键排序和按值排序是Java编程语言中常用的数据结构之一。Map是一种键值对的集合,它可以按照键或值进行排序。下面,我们将详细地介绍Java Map的按键排序和按值排序。 按键...
【Java Map 集合类简介】 在Java的`java.util`包中,集合类扮演着重要的角色,其中List和Map是最为常见的两种。List的实现例如ArrayList和Vector,它们都是可变大小的列表,适合存储和操作各种类型对象的序列。特别...
java Map 转为 Obj Obj 转为 Map
在Java中,"javamap"和"地图_java"可能是指使用Map类来模拟现实世界中的地理地图,例如通过键表示地理位置,值表示该地点的信息。这涉及到自定义类作为键值对中的元素类型,以及如何设计键值对以适应特定需求的问题...
是java Map中几种常用的遍历方法,适合于新手,谢谢
12.javaMap 接口及其实现类.zip12.javaMap 接口及其实现类.zip12.javaMap 接口及其实现类.zip12.javaMap 接口及其实现类.zip12.javaMap 接口及其实现类.zip12.javaMap 接口及其实现类.zip12.javaMap 接口及其实现类....
在Java编程中,`Map`接口是集合框架的一部分,它提供了键值对的存储功能。在处理`Map`对象时,我们经常需要遍历其中的所有元素。本篇将详细介绍Java中遍历`Map`的不同方法,以及如何获取`Map`的长度。 1. **遍历Map...
标题中的"map(java).rar_ map ja_MAP JAVA_java map_java系统_map"暗示了这是一个与Java编程语言相关的项目,特别是涉及到地图(Map)的实现。在Java中,`Map`是一个接口,它定义了键值对的数据结构,允许我们通过键...
13.javaMap接口的两个实现类:.zip13.javaMap接口的两个实现类:.zip13.javaMap接口的两个实现类:.zip13.javaMap接口的两个实现类:.zip13.javaMap接口的两个实现类:.zip13.javaMap接口的两个实现类:.zip13.java...
java map转实体可以利用java的反射去封装,于是就在hibernate的工具类下试着封装了下,封装完了之后感觉没必要,这完全就可以提取出来变成一个独立的工具类,而不仅仅局限于hibernate了,这样既可以满足一个hql查询...
总之,Java Map到Bean的转换是通过反射和JavaBeans规范实现的,这是Java开发中常用的一种数据转换技巧。理解并熟练运用这些知识,能够帮助我们更高效地处理各种数据结构,提升代码的灵活性。在实际项目中,可以根据...
在Java编程中,XML(可扩展标记语言)和Map(映射)是两种常见的数据存储和交换格式。XML因其结构化和易于解析的特性,在数据交换和配置文件中广泛使用,而Map则作为Java中存储键值对的高效数据结构。在实际开发中,...
在Java编程语言中,Map接口提供了键值对的存储方式,但默认情况下,Map并不会按照特定的顺序来存储或返回元素。然而,在某些场景下,我们可能需要将Map中的元素按照值(value)进行排序。本文将详细介绍如何在Java中...
在Java编程语言中,`Map`接口是集合框架的一个重要组成部分,它提供了键值对(key-value pairs)的存储和访问。这篇博文主要探讨了如何遍历Java中的`Map`对象,下面将详细介绍几种常见的遍历`Map`的方法。 1. **...
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集合是一个非常重要的数据结构,它存储键值对,其中每个键都是唯一的。然而,Map默认不保证元素的顺序,如果需要按照特定规则进行排序,我们需要用到特定类型的Map或者手动排序。本文将深入...
主要提供java中的map的遍历实例及效率比较
在这个场景中,我们有一个关于美国邮政编码的Java程序,它利用Map数据结构来高效地管理这些信息。本文将深入探讨这个程序背后的技术细节。 首先,让我们关注标题“美国的邮政编码 全部 java map”。这表明该程序的...