您的位置:首页 > 编程语言 > Java开发

java中Map集合的常用遍历方法及HashMap的应用实例

2016-08-10 15:10 856 查看
HashMap中的

keySet() 方法

返回映射中所包含的键的 set 视图,

返回类型为Set 如果只查询HashMap中的所有键,可以用到这个方法。

entrySet()

返回此映射所包含的映射关系(映射关系是指键值对)的 collection 视图,

在返回的集合中,每个元素都是一个Map.Entry。

与keySet()不同的是,keySet只返回所有的键,

而entrySet则返回的是键值对,不仅包含键,还包括键的值。

所有这里说是“映射(这里指的是Map)所包含的映射关系(键值对关系)”。

Map.Entry 是什么呢?

接口Map.Entry (K指的是键,V指的是值),映射项(键-值对)。

Map.entrySet 方法返回:

映射的 collection 视图,其中的元素属于此类。

获得映射项引用的 惟一 方法:

就是通过此 collection 视图的迭代器来实现。

               (登记entry)

第一种:
  Map map = new HashMap();
  Iterator iter = map.entrySet().iterator();
  while (iter.hasNext()) {
  Map.Entry entry = (Map.Entry) iter.next();
  Object key = entry.getKey();
  Object val = entry.getValue();
  }
  ---------效率高,以后一定要使用此种方式!------------------------
第二种:
  Map map = new HashMap();
  Iterator iter = map.keySet().iterator();
  while (iter.hasNext()) {
  Object key = iter.next();
  Object val = map.get(key);
  }遍历啊

----------------------------------------------------------------------------

Map是java中的接口,Map.Entry是Map的一个内部接口。

Map提供了一些常用方法,如keySet()、entrySet()等方法。

keySet()方法返回值是Map中key值的集合;

entrySet()的返回值也是返回一个Set集合,此集合的类型为Map.Entry。

Map.Entry是Map声明的一个内部接口,此接口为泛型,定义为Entry<K,V>。它表示Map中的一个实体(一个key-value对)。接口中有getKey(),getValue方法。

由以上可以得出,遍历Map的常用方法:

1. Map map = new HashMap();

Irerator iterator = map.entrySet().iterator();

while(iterator.hasNext()) {

Map.Entry entry = iterator.next();

Object key = entry.getKey();

//

}

2.Map map = new HashMap();

Set keySet= map.keySet();

Irerator iterator = keySet.iterator;

while(iterator.hasNext()) {

Object key = iterator.next();

Object value = map.get(key);

//

}

另外,还有一种遍历方法是,单纯的遍历value值,Map有一个values方法,返回的是value的Collection集合。通过遍历collection也可以遍历value,如

Map map = new HashMap();

Collection c = map.values();

Iterator iterator = c.iterator();

while(iterator.hasNext()) {

Object value = iterator.next();

}

--------------------------------------------------

Map的遍历大体有3种:

1、遍历Map.entrySet():它的每一个元素都是Map.Entry对象,这个对象中,

放着的就是Map中的某一对key-value;

2、遍历Map.keySet():它是Map中key值的集合,我们可以通过遍历这个集合来

读取Map中的元素;

3、遍历Map.values():它是Map中value的集合,我们可以直接通过这个集合遍历

Map中的值,却不能读取key。

[java] view
plain copy

package com.sort;

import java.util.HashMap;

import java.util.Iterator;

import java.util.Map;

import java.util.Set;

import java.util.Map.Entry;

/**

* map集合和set集合一样是无序的

* map集合遍历的几种常用方法

* @author Owner

*

*/

public class MapTest5 {

public static void main(String[] args) {

Map<String, String> map = new HashMap<String, String>();

map.put("a", "zhangsan");

map.put("b", "lisi");

map.put("c", "wangwu");

// System.out.println(map);

/**

* 方法一遍历map

*/

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

for(Iterator<String> iterator = keySet.iterator();iterator.hasNext();){

String key = iterator.next();

String value = map.get(key);

System.out.println(key+"="+value);

}

System.out.println("**********************");

/**

* 方法二遍历map

*/

for(String key : map.keySet()){

System.out.println(key+"="+map.get(key));

}

System.out.println("**********************");

/**

* 方法三遍历map,推荐使用该方法遍历map集合,尤其是容量大时

*/

for(Map.Entry<String, String> entry : map.entrySet()){

System.out.println(entry.getKey()+"="+entry.getValue());

}

System.out.println("**********************");

/**

* 方法四遍历map

*/

Set<Entry<String, String>> entrySet = map.entrySet();

for(Iterator<Map.Entry<String, String>> iterator = entrySet.iterator();iterator.hasNext();){

Map.Entry<String, String> entry = iterator.next();

System.out.println(entry.getKey()+"="+entry.getValue());

}

System.out.println("**********************");

/**

* 方法五,这种方法遍历的是所有的值

*/

for(String value : map.values()){

System.out.println(value);

}

}

}

**********方法一************

b=lisi

c=wangwu

a=zhangsan

******方法二遍历****************

b=lisi

c=wangwu

a=zhangsan

**********方法三遍历************

b=lisi

c=wangwu

a=zhangsan

**********方法四遍历************

b=lisi

c=wangwu

a=zhangsan

**********方法五************

lisi

wangwu

zhangsan

Map中元素存放是无序的
HashMap注意事项:

1,HashMap底层维护一个数组,我们向HashMap中所放置的对象实际上是存储在该数组当中;

2,当向HashMap中put一对键值时,它会根据key的hashCode值计算出一个位置,该位置就是此对象准备往数组中存放的位置。

HashMap应用举例:控制台输入一句英语,简单统计各个单词出现的次数

[java] view
plain copy

package com.sort;

import java.util.HashMap;

import java.util.Iterator;

import java.util.Map;

import java.util.Scanner;

import java.util.Set;

/**

* 统计一句英语的简单统计各个单词出现的次数

*

* @author Owner

*

*/

public class MapTest3 {

public static void main(String[] args) {

Scanner sc = new Scanner(System.in);

System.out.println("请输入一句英语,单词间用空格隔开:");

String sentence = sc.nextLine();

String[] arr = sentence.split(" ");

// 键代表着单词,值代表着次数 map.put

Map<String, Integer> map = new HashMap<String, Integer>();

for (int i = 0; i < arr.length; i++) {

if (!map.containsKey(arr[i])) {

map.put(arr[i], 1);

} else {

// 说明map中,存在该元素

int num = map.get(arr[i]);

map.put(arr[i], ++num);

}

}

System.out.println("统计单词出现的个数,结果如下:");

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

for (Iterator<String> iterator = set.iterator(); iterator.hasNext();) {

String key = iterator.next();

Integer value = map.get(key);

System.out.println(key + "=" + value);

}

}

}

输出结果:

请输入一句英语,单词间用空格隔开:

I love U China I am pround to be a Chinese

统计单词出现的个数,结果如下:

to=1

U=1

love=1

am=1

a=1

pround=1

Chinese=1

I=2

China=1


be=1

http://blog.csdn.net/shenshen123jun/article/details/9074523

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: