Java - Смешанные ArrayLists? - PullRequest
       35

Java - Смешанные ArrayLists?

8 голосов
/ 10 июня 2011

Можно ли хранить смесь типов объектов в ArrayList?Если да, то как?

Это то, что я пробовал до сих пор:

List<Object> list = new ArrayList<Object>();

list.add(new String("Hello World"));
list.add(new Integer(1));
list.add(new Long(1l));

for (i = 0; i < list.size(); i++) {
    if (list.get(i) instanceof String){
        sqlPreparedStatement.setString((i+1), (String) list.get(i));
    } else if (list.get(i) instanceof Integer) {
        sqlPreparedStatement.setInt((i+1), (Integer) list.get(i));
    } else if (list.get(i) instanceof Long) {
        sqlPreparedStatement.setLong((i+1), (Long) list.get(i));
    }
}

Но это вызывает исключение при касте.

Заранее спасибо за любой ввод!*

Ответы [ 3 ]

18 голосов
/ 10 июня 2011

Вот что у вас должно быть:

List<Object> list = new ArrayList<Object>();

list.add(new String("Hello World"));
list.add(new Integer(1));
list.add(new Long(1l));

for (Object obj: list) {
    if (obj instanceof String){
        sqlPreparedStatement.setString((String) obj);
    } else if (obj instanceof Integer) {
        sqlPreparedStatement.setInt((Integer) obj);
    } else if (obj instanceof Long) {
        sqlPreparedStatement.setLong((Long) obj);
    }
}
10 голосов
/ 10 июня 2011

Извините, что провалил ваш парад, но вы не должны использовать ArrayList 3 (или любых) разных типов для начала. Если информация связана, создайте класс, который содержит связанную информацию, и создайте ArrayList, который содержит только один тип: объекты этого класса.

Редактировать 1:
Например, скажем класс для хранения данных следующим образом:

class SqlData {
   private String textData;
   private int intData;
   private long longData;

   public SqlData(String textData, int intData, long longData) {
      this.textData = textData;
      this.intData = intData;
      this.longData = longData;
   }

   public String getTextData() {
      return textData;
   }

   public int getIntData() {
      return intData;
   }

   public long getLongData() {
      return longData;
   }

}

и используется так:

  List<SqlData> sqlDataList = new ArrayList<SqlData>();
  sqlDataList.add(new SqlData("Hello World", 1, 11L));

  for (int i = 0; i < sqlDataList.size(); i++) {
     try {
        sqlPreparedStatement.setString(i + 1, sqlDataList.get(i).getTextData());
        sqlPreparedStatement.setInt(i + 1, sqlDataList.get(i).getIntData());
        sqlPreparedStatement.setLong(i + 1, sqlDataList.get(i).getLongData());
     } catch (SQLException e) {
        e.printStackTrace();
     }
  }
5 голосов
/ 10 июня 2011

Почему ты делаешь это так сложно? PreparedStatement имеет метод setObject() - просто используйте его:

    List<Object> list = new ArrayList<Object>();
    list.add(new String("Hello World"));
    list.add(new Integer(1));
    list.add(new Long(1l));
    for (int i = 0; i < list.size(); i++)
        sqlPreparedStatement.setObject(i + 1, list.get(i)); // NOTE: columns count from 1

ПРИМЕЧАНИЕ. Java API Java считает все от 1, а не от нуля, поэтому столбцы нумеруются 1 ... size (), а не 0 ... size () - 1

...