`
哈达f
  • 浏览: 119536 次
  • 性别: Icon_minigender_1
  • 来自: 广西
社区版块
存档分类
最新评论

Map

    博客分类:
  • j2se
 
阅读更多

 

Map:以键值对的形式存入,必须要保证键的唯一性。

    添加:put(key,value):

如果存入已有的键,会发生值覆盖的情况。

    判断:containsKey(key),containsValue(value)

    删除:remove(key)

    个数:size();

    取出:get(key)

当返回为null时,对于HashMap有两种情况,一,该键不存在,二,该键存在对应的值是null。

    取出所有元素:

原理:将Map集合转成Set集合。在通过迭代器取出。

keySet():将Map集合中的所有键取出存入到了Set集合中,在通过迭代器遍历,在遍历过程中,

使用Map集合的get方法取出键所对应的值。

 

entrySet():将Map集合中的键值映射关系取出,被封装成了Map.Entry对象。并将Map.Entry对象存入到了Set集合中。

  通过迭代器取出Map.Entry 对象,并通过该对象的getKey(),getValue()方法取出map集合中的键和值。

 

    取出所有值:values();

|--HashMap:数据结构是哈希表,线程是不安全的,可以存入null键null值。

|--HashTable:数据结构是哈希表,线程是安全的,不可以存入null键null值,被HashMap所取代。

|--TreeMap:数据结构是二叉树,线程是不安全的,可以对Map集合中的键进行排序。

 

什么时候使用Map集合呢?

当分析问题时,对象间出现了映射关系时,就要先想到Map集合。

 

练习:获取字符串中,每一个字母出现的次数。要求结果是:a(3)b(1)....;

 

public String getCharCount(String str)

{

char[] chs = str.toCharArray();

 

int count = 0;

 

TreeMap<Character,Integer> tm = new TreeMap<Character,Integer>();

 

for(int x=0; x<chs.length; x++)

{

if(!(chs[x]>='a' && chs[x]<='z'))

continue;

Integer i = tm.get(chs[x]);

/*

if(i==null)

count++;

else

{

count = i;

count++;

}

*/

 

if(i!=null)

count = i;

count++;

tm.put(chs[x],count);

}

 

StringBuilder sb = new StringBuilder();

 

Iterator<Map.Entry<Character,Integer>> it = tm.entrySet().iterator();

 

while(it.hasNext())

{

Map.Entry<Character,Integer> me = it.next();

Character ch = me.getKey();

Integer x = me.getValue();

sb.append(ch+"("+x+")");

}

 

return sb.toString();

}

 

 

分享到:
评论

相关推荐

    java循环Map java迭代Map

    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以上...

    map.zip_电机_电机MAP_电机效率_电机效率map_绘制电机MAP

    电机MAP(Map,通常指的是性能图或特性曲线)是展示电机效率、功率和其他关键性能参数随转速和转矩变化关系的图表。这种图表对于电机设计、优化和控制系统的研究具有重要意义。 电机效率MAP的绘制涉及到多个步骤和...

    Map (c++实现的简易map)

    在C++编程中,`Map`是一种非常重要的数据结构,它允许我们以键值对的形式存储数据,其中每个键(key)都是唯一的,并且通过这个键可以快速访问对应的值(value)。`Map`通常用于存储关联数组,它提供了一种灵活的...

    GameMap_地图_gamemap_gamemap官网_分割地图_gamemap下_

    《GameMap:游戏地图设计与分割技术详解》 在游戏开发中,地图是构建游戏世界不可或缺的元素。本文将深入探讨GameMap,一种专用于游戏地图设计和管理的工具,以及其中涉及到的关键技术和概念。 首先,我们要理解...

    map_电机_效率map_

    电机效率Map是电机性能分析中的一个重要概念,它用于描述电机在不同工况下运行的效率分布情况。在本文中,我们将深入探讨电机效率Map的绘制方法、意义以及如何利用工具进行计算。 电机效率是指电机输出的机械功率与...

    C语言头文件 MAP C语言头文件 MAP

    C语言头文件 MAPC语言头文件 MAPC语言头文件 MAPC语言头文件 MAPC语言头文件 MAPC语言头文件 MAPC语言头文件 MAPC语言头文件 MAPC语言头文件 MAPC语言头文件 MAPC语言头文件 MAPC语言头文件 MAPC语言头文件 MAPC语言...

    rammap自动运行程序

    **RAMMap工具详解** RAMMap是一款强大的内存分析工具,由微软的 Sysinternals 团队开发,主要用于分析和理解操作系统的内存使用情况。这个工具能够帮助用户深入洞察系统内存的分配和使用,包括物理内存、分页文件...

    map.toString()后转换成Map类型

    ### Map.toString()后转换成Map类型的实现方法及解析 在Java编程中,有时我们需要将一个`Map`对象转换为字符串形式进行存储或传输,而在接收端又需要将该字符串重新转换回`Map`对象以便进一步处理。本篇将详细介绍...

    Scala的Map相关方法整合

    ### Scala的Map相关方法整合 在Scala编程语言中,`Map`是一种常用的数据结构,用于存储键值对。本文将详细介绍Scala中Map的各种方法及其用途,帮助开发者更好地理解和使用这些功能。 #### 1. `def++(xs:Map[(A,B)]...

    map_map_增删查改_STL_C++_

    本节我们将深入探讨STL中的`map`容器,了解其基本概念,并通过实际代码示例展示如何进行增、删、查、改等操作。 `map`容器是一种关联容器,它将唯一的键值与关联的值进行存储,这里的键值通常是用来查找对应值的。`...

    MapBrowser1.2.rar_MapBrows_MapBrowser1.03_mapbrowser 1.2_梦幻_梦幻西游

    《MapBrowser 1.2:梦幻西游的资源探索利器》 MapBrowser 1.2 是一款专为梦幻西游玩家设计的资源提取工具,它以其高效、易用的特性深受用户喜爱。作为一款强大的游戏辅助软件,MapBrowser 1.2 能够帮助玩家深入挖掘...

    详解Python map函数及Python map()函数的用法

    Python的`map()`函数是一个非常实用的内置高阶函数,它的主要作用是对一个或多个序列(通常是列表)的每个元素应用指定的函数,并返回一个新的列表,包含应用函数后的结果。这个函数非常适合在函数式编程中使用,...

    m_map用法详解.rar_M map_m_map_m_map sst_matlab世界地图_世界地图 MATLAB

    《m_map在MATLAB中的应用详解》 MATLAB作为一个强大的数值计算和数据分析工具,其丰富的工具箱使得在各个领域都有广泛的应用。其中,m_map工具箱是专为地图绘制和地理数据分析而设计的,它提供了丰富的函数和数据,...

    C++11 unordered_map与map(插入,遍历,Find)效率对比。

    在C++编程中,`std::map`和`std::unordered_map`是两种常见的关联容器,它们都用于存储键值对,但实现机制和性能特点有所不同。本篇文章将深入探讨这两种容器在插入、遍历和查找操作上的差异,并通过实例分析它们...

    ResultSet 转为listmap

    ResultSet 转为 List&lt;Map&gt; ResultSet 转为 List&lt;Map&gt; 是一种常见的数据处理操作。在 Java 中,使用 JDBC 连接数据库时,通常会返回一个 ResultSet 对象,该对象包含了查询结果集的所有记录。为了方便数据处理和使用...

    c++中map的基本用法和嵌套用法实例分析

    C++中的`map`是一个关联容器,它存储键值对,其中每个键都是唯一的。`map`的数据结构通常实现为红黑树,提供了O(log n)的时间复杂度进行插入、查找和删除操作。下面我们将详细探讨`map`的基本用法和嵌套用法。 ### ...

    素材_tilemap素材_使用TileMap快速构造2D关卡_

    TileMap(瓷砖地图)是一种高效且灵活的工具,常用于构建2D游戏的环境和场景。本素材包主要围绕如何使用TileMap来快速构造2D关卡,帮助开发者节省时间和精力,专注于游戏玩法的创新。 1. TileMap简介: TileMap是2...

    java一键xml转map,一键map转xml工具类

    在Java编程中,XML(可扩展标记语言)和Map(映射)是两种常见的数据存储和交换格式。XML因其结构化和易于解析的特性,在数据交换和配置文件中广泛使用,而Map则作为Java中存储键值对的高效数据结构。在实际开发中,...

    map工具,分析linux生產的map文件

    在Linux系统中,map文件是一种重要的调试和性能分析工具,它包含了程序在内存中的映射信息。本篇文章将深入探讨map工具以及如何分析由Linux生产出的map文件,旨在帮助IT专业人士更好地理解和优化他们的系统。 首先...

    java Pojo转Map

    将Pojo对象转换为Map,可以简化数据处理过程,尤其是在JSP页面上展示数据时,Map的灵活性更加突出。本文将详细介绍如何实现Java中的Pojo到Map的转换,并通过具体的示例来演示这一过程。 首先,我们需要一个Pojo类,...

Global site tag (gtag.js) - Google Analytics