71.【Java.哈希表(散列表)】

简介: 71.【Java.哈希表(散列表)】

1.哈希表的添加(put)

1. put(key,value);对我们所设置的键值对进行赋值的操作;
2. 添加到Map中的数据,与List不一样,是没有顺序的。顺序是根据哈希算法得出的
import java.util.HashMap;
public class Hash {
    public static void main(String[] args) {
      HashMap<String,Double> hashMap=new HashMap<>(10);
      hashMap.put("apple",3.5);
      hashMap.put("organ",1.5);
      hashMap.put("bannda",7.5);
      System.out.println(hashMap);
    }
}

2.哈希表的查询(get)

1.get(key),我们可以通过key找到我们需要的值。
2.通过商品名字查找价格.
import java.util.HashMap;
public class Hash {
    public static void main(String[] args) {
      HashMap<String,Double> hashMap=new HashMap<>(10);
      hashMap.put("apple",3.5);
      hashMap.put("organ",1.5);
      hashMap.put("bannda",7.5);
      System.out.println(hashMap.get("apple"));
    }
}

3.哈希表中是否存在(containsKey/containsValue)

1.containsKey(key);判断key是否包含在这个哈希表中,如果存在true,否则false
2.查看苹果和小猪是否在集合中。
import java.util.HashMap;
public class Hash {
    public static void main(String[] args) {
      HashMap<String,Double> hashMap=new HashMap<>(10);
      hashMap.put("apple",3.5);
      hashMap.put("organ",1.5);
      hashMap.put("bannda",7.5);
      System.out.println(hashMap.containsKey("apple"));
      System.out.println(hashMap.containsKey("pig"));
    }
}

3.containsValue(value);通过value查找是否存在键值对
import java.util.HashMap;
public class Hash {
    public static void main(String[] args) {
      HashMap<String,Double> hashMap=new HashMap<>(10);
      hashMap.put("apple",3.5);
      hashMap.put("organ",1.5);
      hashMap.put("bannda",7.5);
      System.out.println(hashMap.containsValue(3.2));
      System.out.println(hashMap.containsValue(3.5));
    }
}

4.哈希表返回所有Set映射(entrySet)

1.entrySet();返回所有的键值对
import java.util.HashMap;
public class Hash {
    public static void main(String[] args) {
      HashMap<String,Double> hashMap=new HashMap<>(10);
      hashMap.put("apple",3.5);
      hashMap.put("organ",1.5);
      hashMap.put("bannda",7.5);
      System.out.println(hashMap.entrySet());
    }
}

2.哈希表的名字,也可以实现对数据的全部输出
import java.util.HashMap;
public class Hash {
    public static void main(String[] args) {
      HashMap<String,Double> hashMap=new HashMap<>(10);
      hashMap.put("apple",3.5);
      hashMap.put("organ",1.5);
      hashMap.put("bannda",7.5);
      System.out.println(hashMap);
    }
}

5.哈希表返回所有key值(keyset)

1.keySet();返回所有的key值
import java.util.HashMap;
public class Hash {
    public static void main(String[] args) {
      HashMap<String,Double> hashMap=new HashMap<>(10);
      hashMap.put("apple",3.5);
      hashMap.put("organ",1.5);
      hashMap.put("bannda",7.5);
      System.out.println(hashMap.keySet());
    }
}

6.判断哈希表是否为空(isempty)

1.isempty();判断是否为空,如果为空true,反之false

5.哈希表默认值选项(getOrDefault)

8.哈希表对象的复制添加(putAll)

1.putAll(hashMap); 哈希表的复制添加
2.如果在复制的时候,被添加的key值等于key值,会对被添加的值进行覆盖。
import java.util.HashMap;
public class Hash {
    public static void main(String[] args) {
      HashMap<String,Double> hashMap=new HashMap<>(10);
      hashMap.put("apple",3.5);
      hashMap.put("organ",1.5);
      hashMap.put("bannda",7.5);
    HashMap<String,Double> hashMap1=new HashMap<>(10);
      hashMap1.put("apple1",0.5);
      hashMap1.put("organ2",5.5);
      hashMap1.put("bannda",8.5);
//      将哈希集合2的对象全部添加到对象一中
      hashMap.putAll(hashMap1);
        System.out.println(hashMap.entrySet());
    }
}

9.哈希表的遍历(entrySet/keySet遍历法)

entrySet:
1.for(Map.Entry entry:要遍历的哈希对象.entrySet())
import java.util.HashMap;
import java.util.Map;
public class Hash {
    public static void main(String[] args) {
      HashMap<String,Double> hashMap=new HashMap<>(10);
      hashMap.put("apple",3.5);
      hashMap.put("organ",1.5);
      hashMap.put("bannda",7.5);
      for(Map.Entry entry:hashMap.entrySet()){
          System.out.println(entry.getKey()+" "+entry.getValue());
      }
    }
}

1.keySet遍历法:
Set<String> keys = hashMap.keySet();
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
public class Hash {
    public static void main(String[] args) {
      HashMap<String,Double> hashMap=new HashMap<>(10);
      hashMap.put("apple",3.5);
      hashMap.put("organ",1.5);
      hashMap.put("bannda",7.5);
      Set<String> keys = hashMap.keySet();
      for (String key:keys){
          System.out.println(key+" "+hashMap.get(key));
      }
    }
}

10.哈希表的移除(remove)

remove(); 哈希表的移除操作。
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
public class Hash {
    public static void main(String[] args) {
      HashMap<String,Double> hashMap=new HashMap<>(10);
      hashMap.put("apple",3.5);
      hashMap.put("organ",1.5);
      hashMap.put("bannda",7.5);
      hashMap.remove("apple");
        System.out.println(hashMap);
    }
}


相关文章
|
14天前
|
存储 算法 安全
探究‘公司禁用 U 盘’背后的哈希表算法与 Java 实现
在数字化办公时代,信息安全至关重要。许多公司采取“禁用U盘”策略,利用哈希表算法高效管理外接设备的接入权限。哈希表通过哈希函数将设备标识映射到数组索引,快速判断U盘是否授权。例如,公司预先将允许的U盘标识存入哈希表,新设备接入时迅速验证,未授权则禁止传输并报警。这有效防止恶意软件和数据泄露,保障企业信息安全。 代码示例展示了如何用Java实现简单的哈希表,模拟公司U盘管控场景。哈希表不仅用于设备管理,还在文件索引、用户权限等多方面助力信息安全防线的构建,为企业数字化进程保驾护航。
|
5月前
|
存储 Java
数据结构中的哈希表(java实现)利用哈希表实现学生信息的存储
这篇文章通过Java代码示例展示了如何实现哈希表,包括定义结点类、链表类、数组存储多条链表,并使用简单的散列函数处理冲突,以及如何利用哈希表存储和查询学生信息。
数据结构中的哈希表(java实现)利用哈希表实现学生信息的存储
|
7月前
|
存储 Java 索引
JAVA中的哈希表实现与应用
JAVA中的哈希表实现与应用
117 1
|
8月前
|
存储 Java Serverless
Java哈希表
Java哈希表
36 0
|
8月前
|
存储 安全 Java
【亮剑】`ConcurrentHashMap`是Java中线程安全的哈希表,采用锁定分离技术提高并发性能
【4月更文挑战第30天】`ConcurrentHashMap`是Java中线程安全的哈希表,采用锁定分离技术提高并发性能。数据被分割成多个Segment,每个拥有独立锁,允许多线程并发访问不同Segment。当写操作发生时,计算键的哈希值定位Segment并获取其锁;读操作通常无需锁定。内部会根据负载动态调整Segment,减少锁竞争。虽然使用不公平锁,但Java 8及以上版本提供了公平锁选项。理解其工作原理对开发高性能并发应用至关重要。
65 0
|
8月前
|
存储 缓存 安全
Java HashMap:哈希表原理、性能与优化
Java HashMap:哈希表原理、性能与优化
372 1
|
8月前
|
存储 算法 安全
【Java编程进阶之路 02】深入探索:红黑树如何重塑哈希表的性能边界
JDK 1.8之后,HashMap引入红黑树来优化性能,当链表长度超过阈值(默认为8)时,链表会转换为红黑树,从而提高高冲突时的查询效率。同时,HashMap也采用了扰动函数来增加哈希值的随机性,使键值对更均匀分布,提升性能。
91 0
|
8月前
|
存储 缓存 安全
Java ConcurrentHashMap:线程安全的哈希表实现
Java ConcurrentHashMap:线程安全的哈希表实现
185 0
|
8月前
|
存储 缓存 Java
Java LinkedHashMap:保持插入顺序的哈希表解析
Java LinkedHashMap:保持插入顺序的哈希表解析
165 0
|
8月前
|
存储 Java Serverless
哈希表原理与Java HashSet、LinkedHashSet实现
哈希表原理与Java HashSet、LinkedHashSet实现
117 0