1. 前幾天在水木上看到有人問
class Demo>E<{
public Class getDynamicClass(){
Class clazz=//----------------------如何獲取E的類?
return clazz;
}
}
貌似只能這樣解決
class Demo>E<{
E e;
public void addElement(E e){
this.e = e;
}
public Class getDynamicClass(){
Class clazz = e.getClass();
return clazz;
}
}
一些相關評論
Java的范型就是半個殘廢
nod,Java的范型除了防止類型轉換錯誤以外我真想不起來有什么實質的用途。
尤其是那個文檔中說的,編譯的時候拿掉,運行的時候再檢查...
確實沒什么用,jg老糊涂了偏要聽信c++那個bs老頭才有這個敗筆,我一直這么認為
這個東西歐n年前就沒有搞出來
還是有點用的,在ORM中定義多對一或者多對多關系的時候,
List>C< numbers;
這時候偶就知道numbers關聯的是C類,不需要在其它地方再配置了,
為啥沒用
否則對容器的使用還得停留在指針時代
C#的泛型性能還是很好的,只是Java的實現機制那啥了點。。。
最后有人回
很多事情,不要著急下結論。以下代碼算轉載,不算原創。
-------------華麗的分割線---------------------------------
protected Class getDomainClass() {
if (domainClass == null) {
ParameterizedType thisType = (ParameterizedType)
getClass().getGenericSuperclass();
domainClass = (Class)
thisType.getActualTypeArguments()[0];
}
return domainClass;
}
-------------華麗的分割線---------------------------------
還沒試過可不可以
2. 另外一個類似的帖子的回復
System.out.println(((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0]);
試驗了半天
public class BaseClass>M<{
public void showType(){
ParameterizedType ptype = (ParameterizedType) getClass()
.getGenericSuperclass();
System.out.println(ptype.getActualTypeArguments()[0]);
}
}
public class ExClass>M< extends BaseClass>M<{}
new ExClass>Date<().showType(); //得到 "M" 而不是想要的 "Date" :'(
我以前也想這么搞,可是沒搞成,后來看Java關于泛型的實現,認為沒希望。
前面所說的方式只有在
public class SomeClass extends BaseClass>AnotherClass< {...}
這樣定義的時候才能取到AnotherClass ...
3. 看到另一個帖子說運行期沒有范型