将值放入Map的Map中

时间:2013-02-12 22:40:40

标签: java concurrenthashmap

我试图从java中的命令行中读取。

假设我从命令行传递这些参数 -

TABLE1 TABLE2 TABLE3

然后从命令提示符读取后,tableNames列表将包含以上所有三个表名。

private static List<String> tableNames= new ArrayList<String>();

现在我需要遍历此tableNames并通过从属性文件加载相应的值将所有内容放入ConcurrentHashMap

所以我这样做的方式是这样的。

private static ConcurrentHashMap< String,
   ConcurrentHashMap< String, String >> tableList = new ConcurrentHashMap<>();
private static ConcurrentHashMap<String,
   String >                       databaseDetails = new ConcurrentHashMap<>();
prop.load(MainTest.class.getClassLoader().getResourceAsStream("config.properties"));
for (String arg : tableNames) {
   String url = (String) prop.get(arg + ".url");
   String user = (String) prop.get(arg + ".user");
   String password = (String) prop.get(arg + ".password");
   String driver = (String) prop.get(arg + ".driver");
   String suffix = (String) prop.get(arg + ".suffix");
   String sql = (String) prop.get(arg + ".sql");
   databaseDetails.put("URL",url);
   databaseDetails.put("USER",user);
   databaseDetails.put("PASSWORD",password);
   databaseDetails.put("DRIVER",driver);
   databaseDetails.put("SUFFIX",suffix);
   databaseDetails.put("SQL",sql);
   tableList.put(arg,databaseDetails);
}

我不确定这是否是将值放在Map Map中的正确方法?或者我可以稍微提高一点吗?

2 个答案:

答案 0 :(得分:1)

您需要做的主要是在for循环中移动databaseDetails映射的创建。目前,每次循环都会覆盖您在上一次迭代中提取的详细信息。每次循环时,您都在收集一组新的databaseDetails,因此需要一个新的databaseDetails映射来将它们放入。

答案 1 :(得分:1)

这样,表格列表中只有一张地图。您应该在每次迭代中创建一个新的databaseDetails映射。因此,删除databaseDetails成员变量,而不是在循环中使用局部变量。