Java集合-----Map详解

      Map与Collection并列存在。用于保存具有映射关系的数据:Key-Value

  •      Map 中的 key 和  value 都可以是任何引用类型的数据
  •      Map 中的 key 用Set来存放,不允许重复,即同一个,常用String类作为Map的“键”
  •      key 和 value 之间存在单向一对一关系,即通过指定的 key 总能找到唯一的、确定的 value

1.HashMap

HashMap是线程不安全的

package com.gather;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;

public class HashMapPractise {
    public static void main(String[] args) {
        Map<String, Person> map = new HashMap<>();
        Person p1 = new Person("张三", 22);
        Person p2 = new Person("李四", 23);
        Person p3 = new Person("王五", 22);
        map.put("AA", p1);
        map.put("BB", p2);
        map.put("CC", p3);

        //第一种遍历方式:能同时取出键值对
        for(String str:map.keySet()) {
           System.out.println("键为:"+str+",值为:"+map.get(str));
        }
        System.out.println("------------------------------");

        //第二种遍历方式:只取值或只取键
        for(String str:map.keySet()) {
            System.out.println("键为:"+str);
        }

        for(Person person:map.values()) {
            System.out.println("值为:"+person);
        }
        System.out.println("------------------------------");

        //推荐:第三种遍历方式:能同时取出键值对
        for(Entry<String,Person> entry:map.entrySet()) {
            System.out.println("键为:"+entry.getKey()+",值为:"+entry.getValue());
        }
        System.out.println("------------------------------");

        //第四种遍历方式:能同时取出键值对
        Iterator<Entry<String, Person>> entries = map.entrySet().iterator();
        while (entries.hasNext()) {
            Entry<String, Person> entry = entries.next();
            System.out.println("键为:"+entry.getKey()+",值为:"+entry.getValue());
        }
    }
}

   2.Hashtable

Hashtable是线程安全的

package com.gather;

import java.util.Enumeration;
import java.util.Hashtable;
import java.util.Map;
import java.util.Map.Entry;

public class HashtablePractise {
    public static void main(String[] args) {
        Map<String, Person> map = new Hashtable<>();
        Person p1 = new Person("张三", 22);
        Person p2 = new Person("李四", 23);
        map.put("AA", p1);
        map.put("BB", p2);

        for (Entry<String, Person> entry : map.entrySet()) {
            System.out.println("键为:" + entry.getKey() + ",值为:" + entry.getValue());
        }
        System.out.println("------------------------------");

        Hashtable<String, Person> hashtable = new Hashtable<>();
        hashtable.put("AA", p1);
        hashtable.put("BB", p2);

        // Hashtable的另外一种遍历方式:Enumeration
        Enumeration<String> enuKey = hashtable.keys();
        while (enuKey.hasMoreElements()) {
            System.out.println(enuKey.nextElement());
        }

        Enumeration<Person> enuValue = hashtable.elements();
        while (enuValue.hasMoreElements()) {
            System.out.println(enuValue.nextElement());
        }
    }
}

原文地址:https://www.cnblogs.com/fengfuwanliu/p/10430915.html

时间: 2024-11-08 23:53:17

Java集合-----Map详解的相关文章

另外几种Java集合框架详解续

另外几种Java集合框架详解续 作者:chszs,未经博主允许不得转载.经许可的转载需注明作者和博客主页:http://blog.csdn.net/chszs fastutil库优于Trove库的地方:Trove库已经三年未更新了,属于非活跃的开源项目:而fastutil一直在更新.fastutil有更丰富的特性,支持超大的集合(大于2^32,即4GB的集合),文档也更丰富. fastutil是一个开源的Java集合框架的扩展,它继承了Java Collection Framework,提供了数

Java集合类型详解

这篇文章总结了所有的Java集合(Collection).主要介绍各个集合的特性和用途,以及在不同的集合类型之间转换的方式. Arrays Array是Java特有的数组.在你知道所要处理数据元素个数的情况下非常好用.java.util.Arrays 包含了许多处理数据的实用方法: Arrays.asList:可以从 Array 转换成 List.可以作为其他集合类型构造器的参数. Arrays.binarySearch:在一个已排序的或者其中一段中快速查找. Arrays.copyOf:如果你

java集合框架详解

前言: 数据结构对程序设计有着深远的影响,在面向过程的C语言中,数据库结构用struct来描述,而在面向对象的编程中,数据结构是用类来描述的,并且包含有对该数据结构操作的方法. 在Java语言中,Java语言的设计者对常用的数据结构和算法做了一些规范(接口)和实现(具体实现接口的类).所有抽象出来的数据结构和操作(算法)统称为Java集合框架(JavaCollectionFramework). Java程序员在具体应用时,不必考虑数据结构和算法实现细节,只需要用这些类创建出来一些对象,然后直接应

java集合框架详解(一)

1.为什么有java集合框架 线性表,链表,哈希表是常用的数据结构,在进行Java开发时,JDK已经为我们提供了一系列相应的接口.类来实现基本的数据结构.这些类均在java.util包中.在Java语言中,Java语言的设计者对常用的数据结构和算法做了一些规范(接口)和实现(具体实现接口的类).所有抽象出来的数据结构和操作(算法)统称为Java集合框架(Java Collection Framework). Java程序员在具体应用时,不必考虑数据结构和算法实现细节,只需要用这些类创建出来一些对

Java集合框架详解(全)

一.Java集合框架概述 集合可以看作是一种容器,用来存储对象信息.所有集合类都位于java.util包下,但支持多线程的集合类位于java.util.concurrent包下. 数组与集合的区别如下: 1)数组长度不可变化而且无法保存具有映射关系的数据:集合类用于保存数量不确定的数据,以及保存具有映射关系的数据. 2)数组元素既可以是基本类型的值,也可以是对象:集合只能保存对象. Java集合类主要由两个根接口Collection和Map派生出来的,Collection派生出了三个子接口:Li

Java集合用法详解

//1,java.util.Map import java.util.HashMap; import java.util.Iterator; import java.util.LinkedHashMap; import java.util.Map; public class TestLinkedHashMap {   public static void main(String args[])   {    System.out.println("************************

java集合框架详解(二)、set接口

3.1.2 Set接口 首先我们应该知道Set是Collection接口的子接口 Set和Collection基本是一样的,但一点除外:Set无法记住添加的顺序,不允许包含重复的元素.一个不包含重复元素的 collection.更确切地讲,set 不包含满足e 1.equals(e 2)的元素对e 1和e 2,并且最多包含一个 null 元素. 有几点说明: 1.当试图添加两个相同元素进Set集合,添加操作会失败,add()方法返回false. 2.Set判断两个对象是否相等用equals,而不

java内存泄露详解

很多人有疑问,java有很好的垃圾回收机制,怎么会有内存泄露?其实是有的,那么何为内存泄露?在Java中所谓内存泄露就是指在程序运行的过程中产生了一些对象,当不需要这些对象时,他们却没有被垃圾回收掉,而且程序运行中很难发现这个对象,它始终占据着内存却没有发挥作用. 我举这样一个例子,在现实开发中我们需要自定义一个先进后出的栈集合,代码如下: 这个代码看起来和运行起来都没问题,但是,这里有个很隐晦的问题,就是在pop()方法里面,我们首先找到集合最后一个元素的下标,然后按照下标从集合中取出,但是这

转:Java HashMap实现详解

Java HashMap实现详解 转:http://beyond99.blog.51cto.com/1469451/429789 1.    HashMap概述: HashMap是基于哈希表的Map接口的非同步实现.此实现提供所有可选的映射操作,并允许使用null值和null键.此类不保证映射的顺序,特别是它不保证该顺序恒久不变. 2.    HashMap的数据结构: 在java编程语言中,最基本的结构就是两种,一个是数组,另外一个是模拟指针(引用),所有的数据结构都可以用这两个基本结构来构造