此问题的接受答案描述了如何创建 T > Generic< T> 类。这涉及将 Class 参数传递给 Generic 构造函数,并调用 newInstance 方法。
然后创建一个新的通用< Bar> 实例,并且参数 Bar .class 被传入。
如果新的 Generic class不是像 Bar 这样的已知类,但它本身就是一个泛型类型参数?假设我有一些其他的类 Skeet< J> ,并且我想创建一个新的 Generic< J> 在那个班里面然后,如果我尝试传入 J.class ,我得到以下编译器错误:
不能从类型变量中选择。有没有解决方法?
触发错误的代码的特定位是:
public class InputField< W extends Component& WidgetInterface> 扩展了InputFieldArray< W> { public InputField(String labelText) { super(new String [] {labelText},W.class); } / * ... * / } public class InputFieldArray< W extends Component& WidgetInterface> extends JPanel { / * ... * / public InputFieldArray(String [] labelText,Class< W> clazz) throws InstantiationException,IllegalAccessException $ b $ * b for(int i = 0; i
The accepted answer to this question describes how to create an instance of T in the Generic<T> class. This involves passing in a Class<T> parameter to the Generic constructor and callin the newInstance method from that.
A new instance of Generic<Bar> is then created, and the parameter Bar.class is passed in.
What do you do if the generic type parameter for the new Generic class is not some known class like Bar but is itself a generic type parameter? Suppose I had some other class Skeet<J> and I wanted to create a new instance of Generic<J> from inside that class. Then, if I try to pass in J.class I get the following compiler error:
cannot select from a type variable.Is there any way around this?
The specific bit of code triggering the error for me is:
public class InputField<W extends Component & WidgetInterface> extends InputFieldArray<W> { public InputField(String labelText) { super(new String[] {labelText}, W.class); } /* ... */ } public class InputFieldArray<W extends Component & WidgetInterface> extends JPanel { /* ... */ public InputFieldArray(String[] labelText, Class<W> clazz) throws InstantiationException, IllegalAccessException { /* ... */ for (int i = 0 ; i < labelText.length ; i++) { newLabel = new JLabel(labelText[i]); newWidget = clazz.newInstance(); /* ... */ } /* ... */ } /* ... */ }The error happens, because I can't write W.class. Is there some other way of passing in the same information?
解决方案Using .class on a type parameter isn't allowed - because of type erasure, W will have been erased to Component at runtime. InputField will need to also take a Class<W> from the caller, like InputFieldArray:
public InputField(String labelText, Class<W> clazz) { super(new String[] {labelText}, clazz); }
更多推荐
如何从泛型类型参数中获取`.class`属性?
发布评论