欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java集合之HashMap用法详解

程序员文章站 2024-02-24 11:46:16
本文实例讲述了java集合之hashmap用法。分享给大家供大家参考,具体如下: hashmap是最常用的map集合,它的键值对在存储时要根据键的哈希码来确定值放在哪里。...

本文实例讲述了java集合之hashmap用法。分享给大家供大家参考,具体如下:

hashmap是最常用的map集合,它的键值对在存储时要根据键的哈希码来确定值放在哪里。

hashmap 中作为键的对象必须重写object的hashcode()方法和equals()方法

import java.util.map;
import java.util.hashmap;
public class lzwcode {
  public static void main(string [] args) {
    map<integer, string> map = new hashmap<integer, string>();
    map.put(1, "barcelona");
    map.put(2, "realmadrid");
    map.put(3, "manchesterunited");
    map.put(4, "ac milan");
    map.put(5, null);
    map.put(null, null);
    //map.put(null, "chelsea"); //可以运行键值都为空(如果键相同,后者覆盖前者)
    system.out.println(map);
    system.out.print(map.keyset()+" "); //集合中所有键以set集合形式返回
    system.out.println();
    system.out.print(map.values()+" "); //集合中所有键以collection集合形式返回
    system.out.println();
    system.out.println("集合大小:"+map.size());
    system.out.println("是否包含该键:"+map.containskey(2));//返回boolean
    system.out.println("是否包含该值:"+map.containsvalue("barcelona"));//返回boolean
    system.out.println(map.isempty()); //不包含键-值映射关系,则返回true
    map.remove(5); //删除映射关系
    system.out.println(map);
    map.clear();//清空集合
    system.out.println(map);
  }
}

控制台结果:

Java集合之HashMap用法详解

hashmap的两种遍历方法

import java.util.map;
import java.util.hashmap;
import java.util.iterator;
public class lzwcode {
  public static void main(string [] args) {
    map<string, integer> map = new hashmap<string, integer>();
    map.put("barcelona", 1);
    map.put("realmadrid", 2);
    map.put("manchesterunited", 3);
    map.put("ac milan", 4);
    map.put("chelsea", 5);
    //第一种:(效率高)
    system.out.println("第一种方法:");
    iterator iter = map.entryset().iterator();
    while (iter.hasnext()) {
      map.entry entry = (map.entry)iter.next();
      object key = entry.getkey();
      object val = entry.getvalue();
      system.out.println("键:"+key+"<==>"+"值:"+val);
    }
    //第二种:(效率低)
    system.out.println("第二种方法:");
    iterator it = map.keyset().iterator();
    while (it.hasnext()) {
      object key = it.next();
      object val = map.get(key);
      system.out.println("键:"+key+"<==>"+"值:"+val);
    }
    //对于keyset只是遍历了2次,一次是转为iterator,一次就从hashmap中取出key所对于的value。
    //对于entryset只是遍历了第一次,它把key和value都放到了entry中,所以快比keyset快些。
    system.out.println("for-each循环输出");
    //for-each循环
    for (map.entry<string, integer> entry:map.entryset()) {
      string key = entry.getkey().tostring();
      string val = entry.getvalue().tostring();
      system.out.println("键:"+key+"<==>"+"值:"+val);
    }
  }
}

控制台结果:

Java集合之HashMap用法详解

ps:这里再为大家提供2款hash相关在线工具供大家参考使用:

在线散列/哈希算法加密工具:

在线md5/hash/sha-1/sha-2/sha-256/sha-512/sha-3/ripemd-160加密工具:

更多关于java算法相关内容感兴趣的读者可查看本站专题:《java数据结构与算法教程》、《java操作dom节点技巧总结》、《java文件与目录操作技巧汇总》和《java缓存操作技巧汇总

希望本文所述对大家java程序设计有所帮助。