题
我想知道是否有一个类在Java中实现 Map
和 List
接口。
我的数据结构主要是 Map
。我将字符串(ID)映射到 Image
。但是在我的代码的特定部分,我需要向用户提供所有可用的IDed Images
。到目前为止,唯一的方法就是写下这个:
for (String id : myMap.keySet()) {
// get the image like this "myMap.get(id)"
}
所以有一个实现 Map
和 List
的类会很好,所以我可以简单地写一下:
for (Image img : myMap) {
// the image is img
}
有谁知道这样的实现?
编辑:在查看答案(这些都是正确的,已投票)之后,我现在意识到我还需要对地图进行排序。当我说“已排序”时,我的意思是我希望它以特定的顺序获得值,我可以修改它。我知道这不是原来的问题,但我才意识到我需要这个。
编辑2 :我似乎优柔寡断。我需要的是有序地图,而不是有序地图。很抱歉让人感到困惑。
解决方案
如果您需要按特定顺序购买商品,请 LinkedHashMap 是你的朋友 - 它按照插入顺序保存项目。 TreeMap会将您的项目保存在您提供的比较器或密钥的compareTo方法定义的顺序中。
其他提示
对于有序地图,请查看 LinkedHashMap的代码>
。这将使您的密钥按插入顺序排列。
如果您使用 SortedMap 代码>
它将按键排序。 ( TreeMap
是最常见的实现。)
您可以使用的是 map.entrySet()
。这将允许您迭代Set of MapEntries。
查看 javadoc 获取更多信息。
你已经有了很多实际的答案。但直接回答这个问题......
如果有一个类在Java中实现了Map和List接口,我就会徘徊。
......值得一提的是,这根本不可能。 remove(Object)
方法是障碍。
在 Map
界面中,其签名为:
V remove(Object key);
在 List
界面中,它是:
boolean remove(Object o);
您可以使用 < code> Map.values() 方法,返回 Collection
。
这为您提供了存储值的集合
myMap.values()
试试这个:
for (Image img : myMap.values()) {
// the image is img
}
有关排序的地图,请查看 java .util.SortedMap
实现。 java.util.TreeMap
是最常见的选择。如果您只需要保证迭代顺序,可以尝试 java.util.LinkedHashMap中代码>
。它提供的迭代顺序与放置元素到映射的顺序相同。或者,可选地,在最后访问的顺序中。如果您想将键(一旦添加)移动到地图的末尾,则必须明确删除它并重新放置。
您可以使用 TreeMap 它根据其键的自然顺序或在地图创建时提供的比较器进行排序:
TreeMap<String, Image> mapByName = new TreeMap<String, Image>(new ByNameComparator());
其中ByNameComparator()是比较器。或者,您可以使用values()methond并使用Collections.sort()进行排序:
Collection<Image> images = mapByName.values();
Collections.sort(images, new BySizeComparator());