假定我們有這樣一個需求:寫一個排序方法,能夠對整形數組、字符串數組甚至其他任何類型的數組進行排序,該如何實現?
可以使用 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()); } }