Hashmap怎么设置固定大小,当内容占满时,每当插入新数据时,则去掉第一条数据,像队列那样。谢谢!
答案:1 悬赏:30 手机版
解决时间 2021-03-03 19:39
- 提问者网友:放下
- 2021-03-02 23:32
Hashmap怎么设置固定大小,当内容占满时,每当插入新数据时,则去掉第一条数据,像队列那样。谢谢!
最佳答案
- 五星知识达人网友:洒脱疯子
- 2021-03-03 00:43
Hashmap本身做这个功能没有听说过,具体有没有也不清楚,但是我这里可以给你提供一种方案:
(1)使用LinkedHashMap来记录数据,这种map是可以记录key的先后顺序的。
(2)在每次向这个map put数据时:A)检测一下map的大小,是否等于你预设的大小;B)检测要put的key是否不存在于map中。
(3)当同时满足这两个条件时,移除map中的第一个key。移除第一个key的方法是去keySet中的第一个key,这是因为LinkedHashMap的key是按插入顺序排序的。
Set<String> keySet = hashMap.keySet();
Iterator<String> iterator = keySet.iterator();
String firstKey = "";
if (iterator.hasNext()) {
String firstKey = iterator.next();
}
if(!"".equals(firstKey)){
map.remove(firstKey;)
}
(4)最后插入你需要的就可以了。
(1)使用LinkedHashMap来记录数据,这种map是可以记录key的先后顺序的。
(2)在每次向这个map put数据时:A)检测一下map的大小,是否等于你预设的大小;B)检测要put的key是否不存在于map中。
(3)当同时满足这两个条件时,移除map中的第一个key。移除第一个key的方法是去keySet中的第一个key,这是因为LinkedHashMap的key是按插入顺序排序的。
Set<String> keySet = hashMap.keySet();
Iterator<String> iterator = keySet.iterator();
String firstKey = "";
if (iterator.hasNext()) {
String firstKey = iterator.next();
}
if(!"".equals(firstKey)){
map.remove(firstKey;)
}
(4)最后插入你需要的就可以了。
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯