------- android培训、java培训、期待与您交流! ----------
1.泛型,所谓泛型:就是变量类型的参数化。
2.变量类型之前:
类别定义时的逻辑是完全一样的,只是里面的参数变量的类型不同。
如果需要多个相似的类,需要定义多个类型不同的类。
3. 代码参考:
public class testh<T> {
private T foo;
public T getFoo() {
return foo;
}
public void setFoo(T foo) {
this.foo = foo;
}
public static void main(String[] args) {
testh<Boolean> t = new testh<Boolean>();
testh<Integer> i = new testh<Integer>();
t.setFoo(new Boolean(true));
i.setFoo(new Integer(3));
boolean b = t.getFoo();
Integer v = i.getFoo();
System.out.println(b + " " + v);
}
}
遇到的问题:关于Bad version number in .class file的问题
学习之路总是并不平坦的,这不,一开始就遇到问题了:Bad version number in .class file。版本不对?可是我用的java以及javac都是JDK5呀,怎么回事?除了编译版本跟运行版本不一致外是不会出现这种可能的。突然想起前几天试了一下JDK6,把Eclipse的JDK编译器选成JDK6了。果然,将其改回去JDK5就行了。
代码示例:import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
public class Test1 <T extends List>{//注意这里只能使用extends关键字,不能使用implement
private T[] t;
public T[] getT() {
return t;
}
public void setT(T[] t) {
this.t = t;
}
public static void main(String[] args) {
Test1<LinkedList> t = new Test1<LinkedList>();
Test1<ArrayList> t2 = new Test1<ArrayList>();
LinkedList [] link = new LinkedList[]{};
t.setT(link);
System.out.println(t2.getT());
}
}
关于通配符的代码演示:?extend list方法来限定类型持有者的状态。
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
public class Test2<T> {
private T foo;
public T getFoo() {
return foo;
}
public void setFoo(T foo) {
this.foo = foo;
}
public static void main(String[] args) {
Test2<? extends List> te = null;
te = new Test2<ArrayList>();
te = new Test2<LinkedList>();
}
}
注意两者的比较
super:此处表示的是传递的匹配类型只能是super后类型以上的类型。比如List 如果传入arraylist就是错误的。这种情况实际情况中用的比较少。
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
public class Test2<T> {
private T foo;
public T getFoo() {
return foo;
}
public void setFoo(T foo) {
this.foo = foo;
}
public static void main(String[] args) {
Test2<? super List> te = null;
te = new Test2<Object>();
}
}