public class GenericMemoryCell<AnyType> {
private AnyType storeValue;
public void write(AnyType x){
storeValue=x;
}
// public void write(AnyType storeValue){
// this.storeValue=storeValue; //这样写是对的
// }
// public void write(AnyType storeValue)
// {
// storeValue=storeValue; //这样写是错的,因为storeValue是局部变量,如果不用this,标明
//第一个storeValue,不加this,将编译器识别为局部变量storeValue而不是成员变量storeValue
// }
public AnyType read(){
return storeValue;
}
public static void main(String[] args) {
/**
*当指定一个泛型类时,类的声明包含一个或多个类型参数,这些参数被放在类名后面的尖括号里
* 在GenericMemoryCell有一个类型的参数,在这个例子中,对类型参数没有明显的限制,可以是
* <String> <Integer> 但是不能是<int>这样的类型,在GenericMeoryCell类声明内部,我们可以声明
* 泛型类型的域和使用泛型类型作为参数或者返回类型的方法,在类GenericMemoryCell<String>的
* write方法需要一个String类型的参数,如果传递一个其他类型的参数将产生一个编译错误
*/
// GenericMemoryCell<Integer> cell=new GenericMemoryCell<Integer>();
// cell.write(12);
// int i=cell.read();
// System.out.println(i);
GenericMemoryCell<String> cell=new GenericMemoryCell<String>();
cell.write("12");
String i=cell.read();
System.out.println(i);
/**
* 了解
* 也可以声明接口是泛型的,例如在java 1.5以前,Comparable接口不是泛型的,而它的compareTo
* 方法需要一个Object作为参数,于是传递到compareTo方法的任何"引用变量"即使不是一个合理的
* 类型也会都编译,而只是在运行时报 ClassCastException错误,在JAVA 5中 Comparable接口是
* 泛型的,例如String类实现Comparable<String>并有一个compareTo方法,这个方法让String作为
* 其参数通过使类变成泛型类,以前只有在运行时才能报的许多错误,都成了编译时的错误,因为
* 类先编译程字节码文件
* public interface Comparable<String>{
* public int CompateTo(antType other);
* }
* Java 5中的Comparable接口是泛型接口,,JAVA 5 之前的Comparable实现泛型由于超类Object的缘故
*
* */
}
}
Java简单的泛型类和接口
最新推荐文章于 2024-09-15 19:46:31 发布