我在如何使用getClass()获取通用类的T时遇到了一个问题。我想做以下事情:
SimpleTableModel currentTbModel = (SimpleTableModel)jTable.getModel();
Class a = currentTbModel.getModelClass();
NewFrame1<a> newWindow = new NewFrame1<a>();
newWindow.setVisible(true);
我在我的SimpleTableModel中具有getModelClass函数,例如:
public Class<?> getModelClass() {
return (modelData.get(0)).getClass();
}
我以为我可以使用A来完成课程。为了澄清起见,我的SimpleTableModel,NewFrame1和我从中调用这些函数的类都在同一个包中,而类a实际上在另一个包中。因此,当我执行a.getName()时,它将返回otherPackage.myClass。我不确定这是否是问题。
我没有找到任何显示如何使用Class来输入类型参数的答案,所以我希望提出这个问题不会将我链接到通用的getClass解释上,而不是答案。
您在代码中所做的是尝试使用对Class
实例的引用,该实例名为a
作为类型实参。
但是类型参数必须是文字类型名称,例如String
或键入参数。
您只能在方法或类上声明类型参数。
因此您可以在方法上定义类型参数(例如T
),并按如下所示在代码中使用它:
<T> void myMethod() {
//...
SimpleTableModel currentTbModel = (SimpleTableModel)jTable.getModel();
Class<T> a =(Class<T>) currentTbModel.getModelClass();
NewFrame1<T> newWindow = new NewFrame1<T>();
newWindow.setVisible(true);
}
请注意,T
不会添加任何信息,它只是一个句柄,因此您可以将其替换为通配符:
void myMethod() {
//...
SimpleTableModel currentTbModel = (SimpleTableModel)jTable.getModel();
Class<?> a =(Class<T>) currentTbModel.getModelClass();
NewFrame1<?> newWindow = new NewFrame1<?>();
newWindow.setVisible(true);
}
您无法真正改善这一点,因为类型参数在编译时有效,而类实例存在并在运行时运行,因此它们不会影响类型参数。这也意味着NewFrame
的类型参数不能在构造函数中使用。如果要这样做,则必须将类实例作为参数传递给构造函数:
void myMethod() {
//...
SimpleTableModel currentTbModel = (SimpleTableModel)jTable.getModel();
Class<?> a =(Class<T>) currentTbModel.getModelClass();
NewFrame1<?> newWindow = new NewFrame1<?>(a);
newWindow.setVisible(true);
}
当然,它必须在构造函数中声明,并且您可能再次使用通配符或如上所述的命名类型参数。
完整示例,我用来创建此答案:
public class Demo {
public static void main(String[] args) {
new Demo().run();
}
private void run() {
Class<?> aClassInstance = getSomeClass();
TypedClass<?> typedInstance = new TypedClass<>(aClassInstance);
}
private <T> void run2() {
Class<T> aClassInstance = (Class<T>) getSomeClass();
TypedClass<T> typedInstance = new TypedClass<>(aClassInstance);
}
private Class<?> getSomeClass() {
return String.class;
}
static class TypedClass<T> {
TypedClass(Class<T> typeClass) {
}
}
}