`
小杨学JAVA
  • 浏览: 900731 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Set和HashMap

 
阅读更多

 

发现 Set和HashMap之间还是有很多需要注意的地方: 

HashMap<String,String> map = new HashMap<String,String>();
map.put("1", "aa");
map.put("2", "bb");
map.put("3", "aa");
 
Set<String> set = map.keySet();

1.  map的keySet()方法只返回一个set实例,所以当从key1中删除一个对象时候,其他也将会受到影响。

2.  针对于 set不能进行 add操作 ,否则会报“java.lang.UnsupportedOperationException” 。原因 如下 : 

    public Set<K> keySet()返回此映射中所包含的键的 set 视图。该集合受映射的支持,所以映射的变化也反映在该集合中,反之亦然。该集合支持元素的移除,通过          Iterator.remove、Set.remove、removeAll、retainAll 和 clear 操作,从该映射中移除相应的映射关系。它不支持 add 或 addAll 操作。

3. 

  Set<String> set= map.keySet();

  for (String key : set) {

      map.remove(key);

  }

此代码 报这个异常: Exception in thread "main" java.util.ConcurrentModificationException
at java.util.HashMap$HashIterator.nextEntry(Unknown Source)
at java.util.HashMap$KeyIterator.next(Unknown Source)
at com.nan.an.jing.TestSet.main(TestSet.java:23)

原因 为 :  因为删除了一个Entry之后,因为ketSet不正确,在for循环时出的问题。


改正的方法为:

 

 String[] keySet = map.keySet().toArray(new String[0]);

  for (String key : keySet) {

      map.remove(key);

  }

或者 

 Object[] keySet = map.keySet().toArray();
 for (Object key : keySet) {
     map.remove((String)key);
 }


附注 : 代码实例 

 

[java] view plaincopy
  1. package com.nan.an.jing;  
  2.   
  3. import java.util.ArrayList;  
  4. import java.util.HashMap;  
  5. import java.util.Iterator;  
  6. import java.util.List;  
  7. import java.util.Map;  
  8. import java.util.Map.Entry;  
  9. import java.util.Set;  
  10.   
  11. public class TestSet {  
  12.    public static void main(String[] args) {  
  13.      HashMap<String,String> map = new HashMap<String,String>();  
  14.      map.put("1""aa");  
  15.      map.put("2""bb");  
  16.      map.put("3""aa");  
  17.        
  18.      map.remove("1");  
  19.        
  20.      //必须转换为array,或者  String[] keySet = map.keySet().toArray(new String[0]);  
  21.      Object[] keySet = map.keySet().toArray();  
  22.      for (Object key : keySet) {  
  23.        map.remove((String)key);  
  24.      }    
  25.      System.out.println(map);  
  26.        
  27.      // set仅仅一个实例,set删除,map也跟随删除  
  28.      Set<String> set = map.keySet();  
  29.      set.remove("1");  
  30.      System.out.println(set);  
  31.      System.out.println(map);  
  32.    
  33.      // 采用 iterator方法删除 map  
  34.      for(Iterator<String> iterator = set.iterator();iterator.hasNext();)  
  35.      {  
  36.          iterator.next();  
  37.          iterator.remove();  
  38.      }  
  39.      System.out.println(map);  
  40.        
  41.      // 采用iterator方法获取map信息  
  42.      Set<Entry<String, String>> set0 = map.entrySet();  
  43.      for(Iterator<Map.Entry<String, String>> iterator = set0.iterator();iterator.hasNext();){  
  44.          Map.Entry<String, String> mm = iterator.next();  
  45.          String key1 = mm.getKey();  
  46.          String value = mm.getValue();  
  47.      }  
  48.       System.out.println(set0);  
  49.        
  50.       // 采用list增加元素  
  51.      HashMap<String,String> map1 = new HashMap<String,String>();  
  52.      map1.put("1""aa");  
  53.      map1.put("2""bb");  
  54.           
  55.      Set<String> set1 = map1.keySet();  
  56.      List<String> ll = new ArrayList<String>();    
  57.      for(String ss : set1){  
  58.          ll.add(ss);  
  59.      }     
  60.      ll.add("cc");  
  61.      System.out.println(ll);  
  62.      System.out.println(map1);  
  63. }  
  64. }  

http://www.360doc.com/relevant/117933138_more.shtml

转载自:http://blog.csdn.net/qingchun1987_303/article/details/7243973

分享到:
评论

相关推荐

    flash cs6中导入外部的swc文件,as3的使用的ArrayList,Set,Hashmap等工具包

    在AS3中,我们经常会用到几种数据结构,如ArrayList、Set和HashMap,这些数据结构在处理和组织数据时非常有用。这篇博客(尽管链接无法直接查看)可能详细介绍了如何在Flash CS6中导入外部的SWC文件,并在AS3项目中...

    java对象容器(涉及HashMap,ArrayList,Set等)

    在Java中,最常见的对象容器包括ArrayList、List、Set和HashMap等。这些容器各自具有不同的特性和用途,理解并熟练掌握它们对于提升Java编程能力至关重要。 ArrayList是Java集合框架中的一个动态数组,它允许我们在...

    HashMap与HashTable和HashSet的区别

    在Java集合框架中,`HashMap`, `HashTable` 和 `HashSet` 是三个重要的数据结构,它们分别实现了`Map`接口和`Set`接口,提供了不同的功能来满足不同的编程需求。本文将重点分析这三种数据结构之间的区别,特别是针对...

    java 中HashMap、HashSet、TreeMap、TreeSet判断元素相同的几种方法比较

    这些数据结构用于存储和管理数据,其中HashMap和HashSet是基于哈希表实现的,而TreeMap和TreeSet则是基于红黑树(Red-Black Tree)实现的。在处理元素重复性时,它们有不同的策略和效率。 **HashMap** HashMap是一...

    软通动力Java笔试题2011,大家可要把握好机会哦。

    Java 笔试题 2011,涵盖了 Java 中的访问权限控制、List 的非同步实现类、Spring 的自动装配机制、Servlet 和 Jsp 页面的会话管理、J2EE 事务管理、线程状态、UML 中的类管理关系、Set 和 HashMap 中的元素特点等...

    Hashtable和HashMap的区别:

    在Java编程语言中,`Hashtable` 和 `HashMap` 都是用来存储键值对的数据结构。这两种数据结构虽然相似,但是在实现细节上存在显著差异。 1. **Hashtable**:作为 `Dictionary` 类的子类,`Hashtable` 是 Java 最早...

    Java集合专题总结:HashMap 和 HashTable 源码学习和面试总结

    Java集合专题总结:HashMap和HashTable源码学习和面试总结 本文总结了Java集合专题中的HashMap和HashTable,涵盖了它们的源码学习和面试总结。HashMap是一种基于哈希表的集合类,它的存储结构是一个数组,每个元素...

    java算法,数据结构,排序算法,学习路线.zip

    集合和映射提供了更高级的数据组织方式,如Set和HashMap,它们支持特定类型的元素存储和快速查找。 接下来,我们讨论算法。算法是解决问题或执行任务的明确规范,是计算机科学的灵魂。在Java中,算法分为搜索算法、...

    软通动力Java笔试题2011.docx

    Java 相关知识点总结 Java 是一种广泛应用的编程语言,以下是关于 Java 相关知识点的...八、Set 和 HashMap 的特点 Set 中的元素可以为 null,但不可以重复。HashMap 中的 Key 不可以为 Null,value 可以为 Null。

    软通笔试题

    八、Set 和 HashMap Set 中的元素可以为 null,但不可以重复。HashMap 中的 Key 不可以为 Null,value 不可以为 Null。 九、访问修饰符和继承 访问修饰符的使用会影响类和方法的访问权限。在继承关系中,子类可以...

    51. ArrayList LinkedList Set HashMap介绍.txt

    - **允许空键和空值**:`HashMap` 允许一个 null 键和多个 null 值。 - **应用场景**:适用于需要快速查找、插入和删除键值对的场景。例如,存储配置项、缓存数据等。 ### Vector vs ArrayList #### 区别 - **线程...

    Java HashMap类详解

    HashMap 和 HashSet 是 Java Collection Framework 的两个重要成员,虽然它们实现的接口规范不同,但它们底层的 Hash 存储机制完全一样。甚至 HashSet 本身就采用 HashMap 来实现的。 2. Hash 存储机制 HashMap ...

    软通动力Java笔试题1

    Set和HashMap Set中的元素不允许重复,HashMap中的Key不允许为Null,value允许为Null。 Java访问修饰符 假设类A的某个成员方法a()分别具有public、私有、protected、default的访问修饰符,如果希望在B类中调用A的...

    java HashMap原理分析

    为了解决这些问题,HashMap需要重写hashCode和equals方法,以确保两个不同的Key具有不同的哈希码和equals结果。同时,HashMap也需要处理哈希碰撞问题,例如使用链表来存储发生哈希碰撞的Key-Value对。 HashMap是一...

    hashmap 集合

    在Java编程中,HashMap集合是开发者经常使用的数据结构之一,尤其在处理大量数据时,它的高效性和灵活性使得它成为首选。HashMap是Java集合框架的一部分,位于`java.util`包下,实现了Map接口,用于存储键值对(key-...

    用HashMap模拟一个网上购物车

    该项目的主要目的是熟悉Java集合框架中的`HashMap`类,并了解如何利用它来存储、管理和检索数据。此外,我们还将学习如何使用`Scanner`类从键盘接收用户输入。 #### 二、实验需求分析 根据题目要求,我们需要完成...

    rust使用的自定义哈希算法(加上 hashmap/set 别名):快速、确定性_rust_代码_下载

    liballoc 中的 hashmap 默认使用 SipHash,它并没有我们想要的那么快。在编译器中,我们并不真正担心 DOS 尝试,因此我们使用快速非加密哈希。 这与 Firefox 使用的算法相同——它是一种不基于任何广为人知的算法的...

    HashMap CRUD操作

    在本教程中,我们将深入探讨如何使用HashMap来实现产品的创建(Create)、读取(Read)、更新(Update)和删除(Delete),这对于初学者来说是一个很好的实践案例。 **1. HashMap基础** HashMap在内部使用了哈希表...

    hashMap利用iterator迭代器迭代元素方法

    `HashMap`使用哈希表实现,提供快速的插入、删除和查找操作。当我们需要遍历`HashMap`中的所有元素时,通常会使用`Iterator`接口,它是Java集合框架的一部分,提供了对集合的迭代访问。 `Iterator`接口定义了三个...

    treemap treeset hashset hashmap 简要介绍

    在Java编程语言中,集合框架提供了多种数据结构来存储和操作数据,其中`TreeMap`、`TreeSet`、`HashSet`以及`HashMap`是最常用的数据结构之一。这些集合类各自有着独特的特性和应用场景,下面将对它们进行详细介绍。...

Global site tag (gtag.js) - Google Analytics