`
lizhenbin2010
  • 浏览: 101269 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Java遍历、删除Map

    博客分类:
  • J2se
 
阅读更多

      面试的时候,遇到一个很尴尬的事情,就是面试官问怎么样遍历map,以前是做过,但是太久没使用了忘记了,自己查阅了一下书籍,我看的是《Java编程思想》第四版的,因为来深圳没有安顿好,不是经常上网,今天有空来发到博客上,随时谨记与心

先说遍历map:

map是主键对应的,所以要想获取map的值,一般都是通过获取key的方式去get()的,所以第一种方法是,但是第一种方式是获取其值的所有的集合,返回的类型是Collection类型

第一种方式是通过keySet的方式,遍历key的set通过get方法获取

第三种方法是通过汇过去Enty.Map<k, v>的方式获取,这种方式获取的信息很全

下面是我实现的代码:

package com.lzb.common;

import java.util.Collection;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
/**
 * 
 * 功能描述:遍历Map
 *
 * @author  lizhenbin
 *
 * <p>修改历史:(修改人,修改时间,修改原因/内容)</p>
 */
public class QueryMap {
	
	/**
	 * 构建单例模式
	 */
	private static QueryMap instance = null;
	public QueryMap() {};
	public static synchronized QueryMap getInstance() {
		if(instance == null)
			instance = new QueryMap();
		return instance;
	}

	/**
	 * 
	 * 功能描述:用collection存放map的所有值,然后遍历collection
	 *
	 * @author  lizhenbin
	 * <p>创建日期 :May 8, 2012 6:43:52 PM</p>
	 *
	 * @param map
	 * @return
	 *
	 * <p>修改历史 :(修改人,修改时间,修改原因/内容)</p>
	 */
	public static String queryByCollection(Map<Object, Object> map) {
		
		StringBuilder sb = new StringBuilder();
		if(map==null) {
			System.out.println("Usage: Out Map is Null.");
			return null;
		}
		Collection<Object> values = map.values();
		for(Iterator<Object> itor = values.iterator(); itor.hasNext();) {
			Object value = (Object)itor.next();
			sb.append(value + " ");
		}
		return sb.toString();
	}
	
	/**
	 * 
	 * 功能描述:通过map的keySet遍历map
	 *
	 * @author  lizhenbin
	 * <p>创建日期 :May 8, 2012 6:49:46 PM</p>
	 *
	 * @param map
	 * @return
	 *
	 * <p>修改历史 :(修改人,修改时间,修改原因/内容)</p>
	 */
	public static String queryMapBySet(Map<Object, Object> map) {
		
		StringBuilder sb = new StringBuilder();
		if(map==null) {
			System.out.println("Usage: Out Map is Null.");
			return null;
		}
		Set<Object> keySet = map.keySet();
		for(Object key : keySet) {
			Object value = map.get(key);
			sb.append(key + "=" + value + ";");
		}
		sb.deleteCharAt(sb.length()-1);
		return sb.toString();
	}
	
	/**
	 * 
	 * 功能描述:通过Map.Enty遍历map
	 *
	 * @author  lizhenbin
	 * <p>创建日期 :May 8, 2012 6:54:19 PM</p>
	 *
	 * @param map
	 * @return
	 *
	 * <p>修改历史 :(修改人,修改时间,修改原因/内容)</p>
	 */
	public static String queryMapByMapEnty(Map<Object, Object> map) {
		
		StringBuilder sb = new StringBuilder();
		if(map==null) {
			System.out.println("Usage: Out Map is Null.");
			return null;
		}
		Set<Map.Entry<Object, Object>> setMe = map.entrySet();
		for(Map.Entry<Object, Object> me : setMe) {
			Object key = me.getKey();
			Object value = me.getValue();
			sb.append(key + "=" + value + ";");
		}
		sb.deleteCharAt(sb.length()-1);
		return sb.toString();
 	}
}

 

下面就说删除map的值,该情况是我去面试的时候去机试,公司要删除map的值,我当时创建一个map对象的是很,查看方法有remove这个方法,在全面遍历的时候找到对应的key,直接调用该方法,但是老是报异常,当时那个急啊,但是没办法,时间有限,想了一个变通的办法,就是遍历的时候备份一下,重新建立一个map,回来之后,我自己查了一下api文档,貌似说的是访问的冲突吧,好吧,那我就先把key放到一个list中,然后遍历list去删除,欢迎有更加好的办法交流。

这里我把我的两种的实现方法都贴出来。

package com.lzb.common;

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

/**
 * 
 * 功能描述:删除map对应的值信息
 *
 * @author  lizhenbin
 *
 * <p>修改历史:(修改人,修改时间,修改原因/内容)</p>
 */
public class RemoveMapValue {
	
	/**
	 * 构建单例模式
	 */
	private static RemoveMapValue instance = null;
	public RemoveMapValue() {};
	public static synchronized RemoveMapValue getInstance() {
		if(instance == null)
			instance = new RemoveMapValue();
		return instance;
	}
	
	/**
	 * 
	 * 功能描述:采用一个临时map收集适合的信息,将要过滤掉的排除
	 *
	 * @author  lizhenbin
	 * <p>创建日期 :May 5, 2012 6:23:57 PM</p>
	 *
	 * @param map 目标map
	 * @param obj 要删除的对象
	 * @return
	 *
	 * <p>修改历史 :(修改人,修改时间,修改原因/内容)</p>
	 */
	public static Map<Object, Object> rmMapValueByReplace (Map<Object, Object> map, Object obj) {
		
		if(map!=null) {
			
			Map<Object, Object> tempMap = new HashMap<Object, Object>();
			Set<Object> setkeys = map.keySet();
			
			for(Iterator<Object> itor=setkeys.iterator(); itor.hasNext();) {
				
				Object key = itor.next();
				Object value = map.get(key);
				if(value.equals(obj)) {
					tempMap.put(key, value);
				}
			}
			return tempMap;
		} else {
			System.out.println("Usage: Input Map is Null.");
			return null;
		}
	}
	
	/**
	 * 
	 * 功能描述:通过key-value关系删除map信息
	 *
	 * @author  lizhenbin
	 * <p>创建日期 :May 5, 2012 6:26:26 PM</p>
	 *
	 * @param map 源目标map
	 * @param obj 要删除的对象
	 * @return
	 *
	 * <p>修改历史 :(修改人,修改时间,修改原因/内容)</p>
	 */
	public static Map<Object, Object> rmMapValueByKey(Map<Object, Object> map, Object obj) {
		
		List<Object> keyStrs = new ArrayList<Object>();
		if(map!=null) {
			
			Set<Object> setkeys = map.keySet();
			for(Iterator<Object> itor = setkeys.iterator(); itor.hasNext();) {
				Object key = itor.next();
				Object value = map.get(key);
				if(value.equals(obj)) {
					/**
					 * 不能再这一步,直接通过key来删除map的信息
					 * 注意: 在这里map.remove(key); 会报并发访问异常,所以将过滤的map的key全部放在list里面
					 *      通过遍历list再去删除对应的map的信息
					 */
					keyStrs.add(key);
				}
			}
			// 删除map的信息
			for(Object s : keyStrs) {
				map.remove(s);
			}
			return map;
		} else {
			System.out.println("Usage: Input Map is Null.");
			return null;
		}
	}
}

 

分享到:
评论

相关推荐

    java-遍历map

    - 在遍历`Map`时,如果在遍历过程中尝试修改`Map`(例如添加或删除元素),可能会引发`ConcurrentModificationException`异常。因此,在遍历的同时不要修改`Map`。 - 使用流API遍历时,虽然代码更简洁,但性能上可能...

    java遍历Map的几种方法分析

    在Java编程中,Map接口是用于存储键值对的数据结构,它提供了多种遍历Map的方法。本篇文章将详细分析Java中遍历Map的四种常见方法,帮助开发者更好地理解和运用这些技巧。 1. **for-each循环遍历** Java 5引入了...

    java集合map取key使用示例 java遍历map

    本篇文章将详细讲解如何在Java中遍历Map并获取其键(key)。 1. **Map接口概述** Map接口在Java集合框架中定义了存储键值对的方法。每个键都是唯一的,通过键可以访问对应的值。Map接口没有实现List或Set接口,...

    java 遍历MAP的几种方法示例代码

    以下是Java中遍历Map的几种常见方法,包括使用增强的for循环、迭代器以及通过keySet()和entrySet()方法: 1. **增强的for循环(foreach)** 增强的for循环是Java 5引入的新特性,它可以简洁地遍历集合。对于Map,...

    java遍历特例

    ### Java遍历特例知识点详解 #### 一、概述 在Java编程中,遍历Map是一种常见的操作方式,尤其在处理键值对数据时尤为重要。本文档主要介绍了几种常用的遍历`Map`的方法,包括使用传统的迭代器、增强for循环(引入...

    Java遍历Map对象的四种方式

    Java中的Map接口是用于存储键值对的数据结构,它的遍历方法有多种,这里我们将详细介绍四种常见的遍历方式。每种方法都有其适用场景和优缺点,选择合适的遍历方式可以提高代码的效率和可读性。 1. 方式一:使用`...

    Java中如何遍历Map对象的4种方法_.docx

    在 Java 中,遍历 Map 对象是常见的操作,因为我们需要访问和处理存储的键值对。以下是四种遍历 Map 的方法: 1. **使用 for-each 循环遍历 entries** 这是最简单且推荐的遍历方式,适用于需要同时访问键和值的...

    map遍历的四种方式及性能比较

    ### Java中遍历Map的四种方式及性能比较 在Java编程中,`Map`是一种非常重要的数据结构,用于存储键值对。对于`Map`的遍历,不同的遍历方式有着不同的性能表现以及适用场景。本文将详细介绍四种常见的遍历`Map`的...

    Java HashMap 如何正确遍历并删除元素的方法小结

    Java HashMap 遍历和删除元素方法小结 Java HashMap 是一种常用的数据结构,用于存储键值对儿,但是在遍历和删除元素时,需要注意一些特殊的情况,否则可能会出现异常或错误。本文将介绍 Java HashMap 遍历和删除...

    java哈希遍历_哈希遍历_

    在Java编程中,哈希遍历(Hash Traversal)通常是指对哈希表或映射数据结构(如HashMap)中的键值对进行访问的过程。哈希表是一种高效的数据存储方式,它通过计算对象的哈希码来快速定位数据,使得查找、插入和删除...

    Java中遍历Map的多种方法示例及优缺点总结

    在Java编程中,遍历Map是非常常见的操作,用于访问存储的键值对。本文将详细介绍Java中遍历Map的四种主要方法:`keySet`、`values`、`entrySet`以及使用`Iterator`和`Lambda表达式`,并分析它们的优缺点。 1. **...

    易语言仿java集合 list map源码

    对于Map,可能需要实现插入、删除、获取键值对、遍历键值对等功能。 `java对象模块.e`可能是一个包含了易语言中对Java对象模型的实现或者模拟的模块,这个模块可能包括了对Java对象的一些基本操作,如实例化、属性...

    java实现的map排序

    Java中实现Map排序的方式主要有两种,一种是使用TreeMap,另一种是使用SortedMap接口。HashMap内部元素是无序的,它不会记录插入顺序,也不保证顺序。如果需要有序的Map,可以使用TreeMap,它会根据键的自然顺序进行...

    java中map的使用实例

    在Java编程语言中,Map接口是集合框架的重要组成部分,它提供了键值对(key-value pairs)的存储方式。Map不是列表或数组,而是允许我们通过一个键(key)来查找对应的值(value)。本篇文章将深入讲解Map的使用实例...

    Java Map遍历方法

    Java Map遍历方法是编程中常见的操作,尤其是在处理键值对数据时。Map接口在Java中扮演着重要的角色,它提供了存储和检索键值对的能力。以下是对Java Map遍历方法的详细介绍: 1. **使用迭代器遍历**: 这是最基础的...

    Java中的Map&List;

    Java中的Map&List Map和List是Java中两个最基本的数据结构,广泛应用于各种 Java 应用程序中。本文将详细介绍Map和List的概念、实现类、方法和应用场景。 List接口 List接口是Java中的一个基本接口,用于存储一组...

    JavaMap.rar_arraylist map_collection_java map_javamap_地图 java

    Java Map集合类是Java编程语言中用于存储键值对数据结构的重要接口,它与ArrayList、LinkedList等属于Java集合框架的一部分。在Java中,Map接口不继承Collection接口,而是独立存在,因为它代表的是键值对(key-...

    Java Map 集合类简介

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

    Java二维数组实现简单Map

    在Java编程语言中,二维数组可以被用来模拟简单的Map数据结构。Map是一种键值对的集合,其中每个键(Key)都是唯一的,并且与一个值(Value)相关联。尽管Java提供了内置的Map接口(如HashMap、TreeMap等),但有时...

    JAVA_MAP_+_LIST_SET和MAP的区别+_Map的三种遍历方法

    ### JAVA Map、List、Set 的区别 #### 一、概述 在 Java 集合框架中,`Map`、`List` 和 `Set` 是三种非常重要的数据结构,它们各自有着不同的特性和用途。 - **Map**:主要用于存储键值对(key-value pairs)。键...

Global site tag (gtag.js) - Google Analytics