一 、泛型方法
泛型方法的定義與其所在的類是否是泛型類是沒有任何關係的,所在的類可以是泛型類,也可以不是泛型類
二 、定義泛型方法
class Demo{
public <T> T fun(T t){ //可以接收任意類型的數據
return t;
}
}
public class GenericsDemo26 {
public static void main(String[] args) {
Demo d = new Demo();
String str = d.fun("張三");
int i = d.fun(20);
System.out.println(str);
System.out.println(i);
}
}
程序運行結果:
三 、通過泛型方法返回泛型類實例
class Info<T extends Number>{
private T var;
public T getVar() {
return var;
}
public void setVar(T var) {
this.var = var;
}
@Override
public String toString() {
return "Info{" +
"var=" + var +
'}';
}
}
public class GenericsDemo27 {
public static void main(String[] args) {
Info<Integer> i = fun(30);
System.out.println(i.getVar());
}
public static <T extends Number> Info<T> fun(T param){
Info<T> temp = new Info<T>();
temp.setVar(param);
return temp;
}
}
程序運行結果:
四 、使用泛型統一傳入的參數類型
class Info<T>{
private T var;
public T getVar() {
return var;
}
public void setVar(T var) {
this.var = var;
}
@Override
public String toString() {
return "Info{" +
"var=" + var +
'}';
}
}
public class GenericsDemo28 {
public static void main(String[] args) {
Info<String> i1 = new Info<String>();
Info<String> i2 = new Info<String>();
i1.setVar("張三");
i2.setVar("李四");
add(i1,i2);
}
public static <T> void add(Info<T> i1,Info<T> i2){
System.out.println(i1.getVar() + " " + i2.getVar());
}
}
程序運行結果:
以上程序add方法假如傳入的兩個Info對象類型不一致,則編譯錯誤:
class Info<T>{
private T var;
public T getVar() {
return var;
}
public void setVar(T var) {
this.var = var;
}
@Override
public String toString() {
return "Info{" +
"var=" + var +
'}';
}
}
public class GenericsDemo28 {
public static void main(String[] args) {
Info<String> i1 = new Info<String>();
Info<Integer> i2 = new Info<Integer>();
i1.setVar("張三");
i2.setVar(20);
add(i1,i2);
}
public static <T> void add(Info<T> i1,Info<T> i2){
System.out.println(i1.getVar() + " " + i2.getVar());
}
}
故使用泛型統一傳入的參數類型可以爲程序操作的安全性提供保障