4

我试图创造的情况如下:

我有一个包含静态模板方法的基类,该方法接收ResultSet数据库中的查询填充,并返回一个包含正确结果的列表。

我有一些派生自上面引用的类,它们代表数据库中的每个表,并且它们都有一个构造函数来接收ResultSet并构建对象。

我写的代码是:

public class TableBase 
{
    public static <T extends TableBase> List<T> getResults(ResultSet p_Rs) throws SQLException, InstantiationException, IllegalAccessException
    {
        List<T> v_Table = new ArrayList<T>();
        T v_TB = null;
        while(p_Rs.next())
            v_Table.add(new T(p_Rs));
        return v_Table;
    }
}

我得到的错误是:Cannot instantiate the type T

我很清楚,编译器有必要“知道”所有子类都将实现接收ResultSet变量的构造函数,但我无法创建“抽象构造函数”。

有没有人知道如何解决这个问题?

谢谢大家。

4

3 回答 3

2

您不能实例化泛型类型。

您可以使用任一工厂

 public static <T extends TableBase> List<T> getResults
 (ResultSet p_Rs, Factory<T> factory)

//Create instance using factory 

或 Class 作为类型。

public static <T extends TableBase> List<T> getResults
(ResultSet p_Rs, Class<T> type)
//type.newInstance()
于 2012-09-27T03:16:19.553 回答
1

你不能那样做。您必须准确地告诉运行时类型。

也许你可以这样做:</p>

  1. TableBase必须有一个默认构造函数。
  2. TableBase必须有一个 setResultSet 方法。

    public class TableBase {
      public static <T extends TableBase> List<T> getResults(ResultSet p_Rs, Class<T> clazz)
            throws SQLException, InstantiationException, IllegalAccessException {
        List<T> v_Table = new ArrayList<T>();
        T v_TB = clazz.newInstance();
        while (p_Rs.next())
            v_TB.setResultSet(p_Rs);
        v_Table.add(v_TB);
        return v_Table;
      }
    }
    
于 2012-09-27T02:41:15.507 回答
0

您可以使用反射,例如:

while(p_Rs.next())
        v_Table.add(newInstance(T, p_Rs));


public <T extends TableBase> T newInstance(T t, ResultSet p_Rs){
       try {
            Constructor constructor = t.getClass().getDeclaredConstructor(ResultSet.class); 
            return (T)constructor.newInstance(p_Rs);

        } catch (Exception e) {
            throw new RuntimeException();
        } 

}
于 2012-09-27T03:24:36.510 回答