java中HashMap类用法

简介:   /* HashSet底层是采用HasMap实现的  HasMap保存的是  键值对 就跟 C++中 容器类似 keySet() 返回键的视图  values() 返回值的视图 entrySet()  返回的每一个元素都是Map.
 

/*
HashSet底层是采用HasMap实现的  HasMap保存的是  键值对
就跟 C++中 <map>容器类似
keySet() 返回键的视图  values() 返回值的视图

entrySet()  返回的每一个元素都是Map.Entry     Map中一个静态的接口接收键值对 
*/
import java.util.* ;
class  Test
{ private static HashMap<String,String> hm=new HashMap<String,String>() ;  //JDK1.5后引入范式概念
 public static void main(String []args)
 {
  hm.put("one","xiaoming") ;// 向其中添加键值对 因为没有实现Collection接口所以没有add方法
  hm.put("two","xiaozhang") ;
  hm.put("three","xiaoli") ;
  hm.put("four","xiaoliu") ;
  System.out.println(hm.get("one"));
  System.out.println(hm.get("two"));
    System.out.println(hm.get("three"));
    System.out.println(hm.get("four"));  
 
   
    Set s=hm.keySet() ;//返回键的视图 
    printElements(s);  //输出键列表
 
 
 
   
    Collection c=hm.values();
    printElements(c); //迭代器的好处是可以输出多种类型的数据    输出值列表
 
 
   
    Set ss=hm.entrySet() ;//返回Map.Entry 接口实现
    printElements(ss);   //输出键值对  利用迭代器 
   
  
  
  
    Iterator  i=ss.iterator() ;   //通过 Map.Entry静态接口 获取元素
    while(i.hasNext())
    {
     Map.Entry me=(Map.Entry)i.next() ;//强制转换
     System.out.println(me.getKey()+":"+me.getValue());
     
    }
   
   
   
   
  
 }
 
static public void printElements(Collection c)
 {
  Iterator i=c.iterator() ;
  while(i.hasNext())
  {
   System.out.println(i.next());
  }
  
  
 }
 
 
 
}

目录
相关文章
|
1月前
|
存储 Java 索引
用Java语言实现一个自定义的ArrayList类
自定义MyArrayList类模拟Java ArrayList核心功能,支持泛型、动态扩容(1.5倍)、增删改查及越界检查,底层用Object数组实现,适合学习动态数组原理。
87 4
|
1月前
|
IDE JavaScript Java
在Java 11中,如何处理被弃用的类或接口?
在Java 11中,如何处理被弃用的类或接口?
161 5
|
1月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
143 1
|
1月前
|
Java Go 开发工具
【Java】(8)正则表达式的使用与常用类分享
正则表达式定义了字符串的模式。正则表达式并不仅限于某一种语言,但是在每种语言中有细微的差别。
203 1
|
1月前
|
存储 Java 程序员
【Java】(6)全方面带你了解Java里的日期与时间内容,介绍 Calendar、GregorianCalendar、Date类
java.util 包提供了 Date 类来封装当前的日期和时间。Date 类提供两个构造函数来实例化 Date 对象。第一个构造函数使用当前日期和时间来初始化对象。Date( )第二个构造函数接收一个参数,该参数是从1970年1月1日起的毫秒数。
148 1
|
1月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
160 1
|
1月前
|
编解码 Java 开发者
Java String类的关键方法总结
以上总结了Java `String` 类最常见和重要功能性方法。每种操作都对应着日常编程任务,并且理解每种操作如何影响及处理 `Strings` 对于任何使用 Java 的开发者来说都至关重要。
263 5
|
5月前
|
存储 安全 Java
Java 集合面试题从数据结构到 HashMap 源码剖析详解及长尾考点梳理
本文深入解析Java集合框架,涵盖基础概念、常见集合类型及HashMap的底层数据结构与源码实现。从Collection、Map到Iterator接口,逐一剖析其特性与应用场景。重点解读HashMap在JDK1.7与1.8中的数据结构演变,包括数组+链表+红黑树优化,以及put方法和扩容机制的实现细节。结合订单管理与用户权限管理等实际案例,展示集合框架的应用价值,助你全面掌握相关知识,轻松应对面试与开发需求。
295 3
|
Java
让星星⭐月亮告诉你,HashMap中保证红黑树根节点一定是对应链表头节点moveRootToFront()方法源码解读
当红黑树的根节点不是其对应链表的头节点时,通过调整指针的方式将其移动至链表头部。具体步骤包括:从链表中移除根节点,更新根节点及其前后节点的指针,确保根节点成为新的头节点,并保持链表结构的完整性。此过程在Java的`HashMap$TreeNode.moveRootToFront()`方法中实现,确保了高效的数据访问与管理。
117 2
|
Java 索引
让星星⭐月亮告诉你,HashMap之往红黑树添加元素-putTreeVal方法源码解读
本文详细解析了Java `HashMap` 中 `putTreeVal` 方法的源码,该方法用于在红黑树中添加元素。当数组索引位置已存在红黑树类型的元素时,会调用此方法。具体步骤包括:从根节点开始遍历红黑树,找到合适位置插入新元素,调整节点指针,保持红黑树平衡,并确保根节点是链表头节点。通过源码解析,帮助读者深入理解 `HashMap` 的内部实现机制。
188 2