假定我們有這樣一個需求:寫一個排序方法,能夠對整形數組、字符串數組甚至其他任何類型的數組進行排序,該如何實現?
可以使用 Java 泛型。使用 Java 泛型的概念,我們可以寫一個泛型方法來對一個對象數組排序。然後,調用該泛型方法來對整型數組、浮點數數組、字符串數組等進行排序。
定義泛型方法的規則:
public class GenericTest{
public static <E> void printArray(E[] inputArray){
for(E element:inputArray){
System.out.print(element+" ");
}
System.out.println("");
}
public static void main(String args[]){
Integer[] intArray={1,2,3,4,5};
Double[] doubleArray={1.1,2.2,3.3,4.4,5.5};
Character[] charArray={'h','e','l','l','o'};
//這裡不能寫成int、double、char
printArray(intArray);
printArray(doubleArray);
printArray(charArray);
}
}
有界的類型參數:
可能有時候,你會想限制那些被允許傳遞到一個類型參數的類型種類范圍。例如,一個操作數字的方法可能只希望接受Number或者Number子類的實例。這就是有界類型參數的目的。
要聲明一個有界的類型參數,首先列出類型參數的名稱,後跟extends關鍵字,最後緊跟它的上界。
public class MaximumTest
{
// 比較三個值並返回最大值
public static <N extends Comparable<N>> N maximum(N x, N y, N z)
{
N max = x; // 假設x是初始最大值
if ( y.compareTo( max ) > 0 ){
max = y; //y 更大
}
if ( z.compareTo( max ) > 0 ){
max = z; // 現在 z 更大
}
return max; // 返回最大對象
}
public static void main( String args[] )
{
System.out.printf( "%d, %d 和 %d 中最大的數為 %d\n\n",
3, 4, 5, maximum( 3, 4, 5 ) );
System.out.printf( "%.1f, %.1f 和 %.1f 中最大的數為 %.1f\n\n",
6.6, 8.8, 7.7, maximum( 6.6, 8.8, 7.7 ) );
System.out.printf( "%s, %s 和 %s 中最大的數為 %s\n","pear",
"apple", "orange", maximum( "pear", "apple", "orange" ) );
}
}
泛型類:
泛型類的聲明和非泛型類的聲明類似,除了在類名後面添加了類型參數聲明部分。
和泛型方法一樣,泛型類的類型參數聲明部分也包含一個或多個類型參數,參數間用逗號隔開。一個泛型參數,也被稱為一個類型變量,是用於指定一個泛型類型名稱的標識符。因為他們接受一個或多個參數,這些類被稱為參數化的類或參數化的類型。
public class Box<T> {
private T t;
public void add(T t) {
this.t = t;
}
public T get() {
return t;
}
public static void main(String[] args) {
Box<Integer> integerBox = new Box<Integer>();
Box<String> stringBox = new Box<String>();
integerBox.add(new Integer(10));
stringBox.add(new String("菜鳥教程"));
System.out.printf("整型值為 :%d\n\n", integerBox.get());
System.out.printf("字符串為 :%s\n", stringBox.get());
}
}