如标题所示我想知道是否存在任何可以允许这样的结构:
key = 1 - > arrayList1,arrayList2,arrayList3 ......
someStructure.add(1,arrayList<1>);
someStructure.add(1,arrayList<2>);
someStructure.add(1,arrayList<3>);
重要
每个列表的键必须保持不变。
答案 0 :(得分:4)
您可以使用Map
Map<YourKeyClass, List<Data>> someStructure
= new HashMap<YourKeyClass, List<Data>>();
根据您的需要,您需要:
Map<YourKeyClass, List<List<Data>>> someStructure
= new HashMap<YourKeyClass, List<List<Data>>>();
以下是结构的启动示例:
class MyMapOfList<K, V> {
Map<K, List<V>> innerMap;
public MyMapOfListOfList() {
innerMap = new HashMap<K, V>();
}
public void put(K key, V value) {
List<V> list = innerMap.get(key);
if (list == null) {
list = new ArrayList<V>();
innerMap.put(key, list);
}
list.add(value);
}
}
你可以像这样使用它:
MyMapOfList<String, List<Data>> myMapOfList;
如果您不想在List
内部添加/维护Map
s,您可以使用来自第三方库的结构,例如来自Guava的MultiMap
,其行为更多喜欢你想要/需要。
更多信息:
答案 1 :(得分:1)
HashMap<Key,Value>
可以做到。
SSCCE:
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class Number {
public static void main(String[] args) {
try {
Map mMap = new HashMap();
mMap.put("PostgreSQL", "Free Open Source Enterprise Database");
mMap.put("DB2", "Enterprise Database , It's expensive");
mMap.put("Oracle", "Enterprise Database , It's expensive");
mMap.put("MySQL", "Free Open SourceDatabase");
Iterator iter = mMap.entrySet().iterator();
while (iter.hasNext()) {
Map.Entry mEntry = (Map.Entry) iter.next();
System.out.println(mEntry.getKey() + " : " + mEntry.getValue());
}
mMap.put("Oracle", "Enterprise Database , It's free now ! (hope)");
System.out.println("One day Oracle.. : " + mMap.get("Oracle"));
} catch (Exception e) {
System.out.println(e.toString());
}
}
}
来源:http://www.mkyong.com/java/how-to-use-hashmap-tutorial-java/