Java ArrayList <arraylist <string>&gt;关于孩子的clear()清除父

时间:2017-04-20 10:40:26

标签: java arraylist

我有2个arraylists:

ArrayList<ArrayList<String>> res= new ArrayList();
ArrayList<String> data= new ArrayList();

在我将结果集添加到child并将child附加到parent之后,我在.clear()上调用data来重置索引。

问题是.clear()同时丢弃了孩子和父母。

为什么有任何想法?

最后,从整个结果集中我得到最后一行重复10次。

public ArrayList<ArrayList<String>> getTemplateTableData() {
    ArrayList<ArrayList<String>> res = new ArrayList();
    ArrayList<String> data = new ArrayList();
    CDb cb = new CDb();
    OracleConnection conn = cb.getConn();
    OraclePreparedStatement ps = null;
    OracleResultSet rs = null;
    OracleResultSetMetaData rsm = null;
    try {
      ps = (OraclePreparedStatement)
              conn.prepareStatement("Select * From Va_User_Infos_V t Where t.User_Id = 1");
      ps.execute();
      rs = (OracleResultSet)ps.getResultSet();
      rsm = (OracleResultSetMetaData)rs.getMetaData();
      while(rs.next()) {
        int col = 2;
        data.clear();
        System.out.println(data);
        while(col < rsm.getColumnCount()) {
          col++;
          data.add(rs.getString(col));
        }
        res.add(data);
        System.out.println(data);
      }
      System.out.println(res);
    } catch(Exception e) {
      e.printStackTrace();
    } finally {
      cb.done(rs);
      cb.done(ps);
      cb.done(conn);
    }
    return res;
  }

输出:

[]
[1Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8]
[]
[2Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8]
[]
[3Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8]
[]
[4Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8]
[]
[5Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8]
[]
[6Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8]
[]
[7Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8]
[]
[8Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8]
[]
[9Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8]
[]
[10Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8]
[[10Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8], 
 [10Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8], 
 [10Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8], 
 [10Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8], 
 [10Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8], 
 [10Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8], 
 [10Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8], 
 [10Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8], 
 [10Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8], 
 [10Col-1, Col-2, Col-3, Col-4, Col-5, Col-6, Col-7, Col-8]]

最终目的是解析父列表并将数据添加到XWPF docx表中。

解决方案:

  while(rs.next()) {
    int col = 2;
    data.clear();
    while(col < rsm.getColumnCount()) {
      col++;
      data.add(rs.getString(col));
    }
    ArrayList clone = (ArrayList)data.clone();
    res.add(clone);
  }

1 个答案:

答案 0 :(得分:4)

您正在做什么:将子列表的引用放入父列表中。

您没有创建子列表的副本。只需在不同的地方引用相同列表。

惊喜:当你现在修改那个子列表时(无论你做什么:添加,删除,清除,排序......)所有其他引用都会显示更改的内容!

两种解决方案:

  • 创建子列表;并且不要在之后修改将列表添加到父列表
  • “展平”您的父列表(也将其设为List<String>);并使用addAll()添加子列表的内容