Java 之HashMap.values()方法误用

 1.出错

   今天在测试代码的时候发现程序报错,看代码才知道是使用HashMap.values()方法的时候出错。因为项目中需要获取Map的值的集合然后进行遍历,所以就很自然的调用了HashMap.values()方法,如下所示

package collections;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class Test {

	/**
	 * @param args
	 */
	public static void main(String[] args) {

		Map<String,String> map = new HashMap<String,String>();
		map.put("A", "A");
		map.put("B", "B");
		map.put("C", "C");
		map.put("D", "D");
		map.put("E", "E");
		List<String> valuesList = (List<String>) map.values();
		for(String str:valuesList){
			System.out.println(str);
		}
	}

}

  运行时候抛出异常,异常信息如下:

Exception in thread "main" java.lang.ClassCastException: java.util.HashMap$Values cannot be cast to java.util.List
	at collections.Test.main(Test.java:20)

  2.错误原因分析

  首先找到了values()方法所在的源码,信息如下:

  public Collection<V> values() {
        Collection<V> vs = values;
        return (vs != null ? vs : (values = new Values()));
    }

  原来values()方法只是返回了一个Collection集合,可是如程序中的用法所示,在向下转型的时候出现了类型转换错误。那我们应该怎么才能获取自己想要的结构呢?

3.解决方法

  在ArrayList中,有一个构造函数

    public ArrayList(Collection<? extends E> c) {
        elementData = c.toArray();
        size = elementData.length;
        // c.toArray might (incorrectly) not return Object[] (see 6260652)
        if (elementData.getClass() != Object[].class)
            elementData = Arrays.copyOf(elementData, size, Object[].class);
    }

  可以接受一个集合类型的参数,然后返回一个list;这样就达到了预期目的。代码如下

package collections;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class Test {

	/**
	 * @param args
	 */
	public static void main(String[] args) {

		Map<String,String> map = new HashMap<String,String>();
		map.put("A", "A");
		map.put("B", "B");
		map.put("C", "C");
		map.put("D", "D");
		map.put("E", "E");
		//List<String> valuesList = (List<String>) map.values();
		List<String> valuesList = new ArrayList<String>(map.values());
		for(String str:valuesList){
			System.out.println(str);
		}
	}

}

  

时间: 2024-08-06 22:13:31

Java 之HashMap.values()方法误用的相关文章

java中HashMap的基本方法使用

遍历,添加词,等等 package test; import java.util.HashMap; import java.util.Iterator; import java.util.ArrayList; import java.util.Collection; import java.util.Map.Entry; import java.util.Set; public class test6 { public static void main(String[] args) { Hash

千万不要误用 java 中的 HashCode 方法

刚才debug追堆栈的时候发现一个很奇怪的问题 我用IE8和Google的浏览器访问同一个地址 Action的 scope="session" 也设置了 而且两个浏览器提交的参数map也是互相独立的 不过很奇怪的一个 两个Action对象的hashmap是不同的但是它们的对象变量 paraterMap 的 哈希值 居然是一个 我大不解!( 找到原因以后发现这个问题其实只是一个好多年没有再提起的基础问题 ) 不过发现确实有朋友在网上说这个问题曾经引发过bug Java中的hashCode

Java遍历Map集合方法

package testMap; import java.util.ArrayList; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; import java.util.Map.Entry; import java.util.Set; /**  * 循环遍历Map集合  *   * @author Administrator  *   */ pub

How java implements HashMap

1. How java implements HashMap HashMap Custom implementation in java - How HashMap works internally with diagrams and full program http://www.javamadesoeasy.com/2015/02/hashmap-custom-implementation.html 2. HashMap interview question 17.在Java中,HashMa

HashMap.values().addAll()异常

问题:在使用一个Collection.addAll()方法时报告UnsupportedOperationException.追溯原因发现该collection是来自于hashMap.values(). 分析原因:通过查看源代码,发现hashMap.values()实现如下:    //HashMap.java    public Collection<V> values() {         Collection<V> vs = values;         return (v

Java 笔记 -HashMap

HashMap使用的数据结构,专业术语"链表散列",代码实 /** * 定义了一个Entry的数组用来存储数据. */ transient Entry[] table; ```java /** * Entry是内部定义的类 */ static class Entry<K,V> implements Map.Entry<K,V> { /** * 定义了两个常量key,就是HashMap的key * value,key对应的value * next,下一个Entry

java集合类遍历删除方法测试以及使用场景记录

package test0; import java.util.List; import java.util.Map; import java.util.Map.Entry; import java.util.Set; import java.util.ArrayList; import java.util.HashMap; import java.util.HashSet; import java.util.Iterator; import java.util.LinkedList; /**

Java的HashMap是如何实现的?

HashMap.java源代码: /* * Copyright (c) 1997, 2010, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * * * * * * * * * * * * * * * * * * * * */ package java.util; import java.io.*; /**

聊聊JVM(三)两种计算Java对象大小的方法

这篇说说如何计算Java对象大小的方法.之前在聊聊高并发(四)Java对象的表示模型和运行时内存表示 这篇中已经说了Java对象的内存表示模型是Oop-Klass模型. 普通对象的结构如下,按64位机器的长度计算 1. 对象头(_mark), 8个字节 2. Oop指针,如果是32G内存以下的,默认开启对象指针压缩,4个字节 3. 数据区 4.Padding(内存对齐),按照8的倍数对齐 数组对象结构是 1. 对象头(_mark), 8个字节 2. Oop指针,如果是32G内存以下的,默认开启对