加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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

发布时间:2020-12-14 05:43:31 所属栏目:Java 来源:网络整理
导读:我需要一个Map但是当我调用get(key,n)时,它应该不仅应该返回具有搜索键值的所有记录,而且还应该返回键的n个最后有效位与搜索键相同的所有记录(例如,应用诸如key(1(n 1)-1))之类的东西. 是否已经在 Java中实现了这样的东西? 解决方法 不完全,但您可以使用 Na
我需要一个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);

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读