在Java世界中是否存在具有可变密钥长度的Map?

我需要一个Map但是当我调用get(key,n)时,它应该不仅应该返回具有搜索键值的所有记录,而且还应该返回键的n个最后有效位与搜索键相同的所有记录(例如,应用诸如key&(1<<(n 1)-1))之类的东西. 是否已经在 Java中实现了这样的东西?

解决方法

不完全,但您可以使用 NavigableMap.subMap来实现这一点.例如
NavigableMap<Integer,Value> map =
int keyBase = key & ~((1 << n)-1);
Map<Integer,Value> subMap = map.subMap(keyBase,true,keyBase + (1 << n),false);

如果要基于最低位而不是最高位进行搜索,则必须在添加搜索之前反转这些位.这将最低位,第二低位和第三低位等组合在一起.

相关文章

ArrayList简介:ArrayList 的底层是数组队列,相当于动态数组。与 Java 中的数组相比,它的容量能动态增...
一、进程与线程 进程:是代码在数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位。 线程...
本文为博客园作者所写:&#160;一寸HUI,个人博客地址:https://www.cnblogs.com/zsql/ 简单的一个类...
#############java面向对象详解#############1、面向对象基本概念2、类与对象3、类和对象的定义格式4、...
一、什么是异常? 异常就是有异于常态,和正常情况不一样,有错误出错。在java中,阻止当前方法或作用域...
Collection接口 Collection接口 Collection接口 Collection是最基本的集合接口,一个Collection代表一组...