首页 > 文章列表 > Java 泛型方法的定义和使用技巧

Java 泛型方法的定义和使用技巧

java 泛型方法
180 2024-04-23

答案: Java 中的泛型方法允许代码与多种类型兼容。定义: 使用尖括号 <T> 指定参数和返回值的类型信息。使用: 可用于操作不同类型的集合和比较不同类型的对象。受限类型参数: 通过 extends 关键字指定类型受限于某个类型。实战: 泛型方法适用于创建通用的排序算法,例如快速排序。

Java 泛型方法的定义和使用技巧

Java 泛型方法的定义和使用技巧

简介

泛型方法允许你编写在多种类型上都能工作的代码,从而提高了代码的可重用性和灵活性。

定义泛型方法

要定义泛型方法,请在方法名称后使用尖括号 <> 指定类型参数:

public static <T> void swap(T[] array, int i, int j) {
    T temp = array[i];
    array[i] = array[j];
    array[j] = temp;
}

在这个例子中,<T>表示方法的参数和返回值的类型信息未知。

泛型方法的使用

可以使用泛型方法来操作不同类型的集合:

Integer[] numbers = {1, 2, 3};
swap(numbers, 0, 2); // 交换数字 1 和 3

同样,也可以用泛型方法来比较不同类型的对象:

public static <T extends Comparable<T>> int compare(T a, T b) {
    return a.compareTo(b);
}

int result = compare("Hello", "World"); // 比较字符串

使用Bounded类型参数

你可以使用extends关键字来指定泛型类型参数受某种类型的约束:

public static <T extends Number> double sum(T[] array) {
    double total = 0.0;
    for (T element : array) {
        total += element.doubleValue();
    }
    return total;
}

double sum = sum(new Integer[]{1, 2, 3}); // 求整数和

实战案例:排序算法

泛型方法非常适合创建通用的排序算法,例如快速排序:

public static <T extends Comparable<T>> void quickSort(T[] array) {
    // 略...
}

// 排序整数数组
int[] numbers = {2, 5, 1, 7, 3};
quickSort(numbers);

// 排序字符串数组
String[] strings = {"Hello", "World", "Java"};
quickSort(strings);