java中在定义泛型泛型方法是方法名前加上泛型有什么作用?
展开全部
static <T> void show(Collection<T> C){
}
//这个泛型方法中定义了一个T类型形参,这个T类型形参可以在该方法内当成普通类型使用。这里无需显示传入实际类型参数,无论调用该方法时传入什么类型的值,系统都可以判断出最直接的类型参数。举个例子给你看可能会更加明白:
import java.util.*;
public class 泛型Test
{
static <T> void show(Collection<T> C)
{
System.out.println("使用泛型 ------->" + C);
}
static void show2(Collection C)
{
System.out.println( C);
}
public static void main(String[] args)
{
Collection<String> C = new HashSet<>();
C.add("第一个元素");
//下面这行代码调用show方法时会出错,因为无法通过方法调用转换将实际参数int转换为String
//因为编译器会根据实参推断类型形参的值,所以系统都可以判断出最直接的类型参数为String
//C.add(58);
泛型Test.show(C);
泛型Test.show2(C);
Collection d = new HashSet();
//由于java在设计集合时,并不知道我们用它来保存什么类型的对象,所以便设计成可以保存任
//何类型的对象。同时也带了问题,集合只是知道它装了Object类型的值,取出元素时还需要进
//行强制类型转换,增加了编程复杂度,也容易引发ClassCastException。下面两行代码中添加
//两种不同类型的元素,没有错误。
d.add(2);
d.add("第二个元素");
泛型Test.show(d);
泛型Test.show2(d);
}
}
}
//这个泛型方法中定义了一个T类型形参,这个T类型形参可以在该方法内当成普通类型使用。这里无需显示传入实际类型参数,无论调用该方法时传入什么类型的值,系统都可以判断出最直接的类型参数。举个例子给你看可能会更加明白:
import java.util.*;
public class 泛型Test
{
static <T> void show(Collection<T> C)
{
System.out.println("使用泛型 ------->" + C);
}
static void show2(Collection C)
{
System.out.println( C);
}
public static void main(String[] args)
{
Collection<String> C = new HashSet<>();
C.add("第一个元素");
//下面这行代码调用show方法时会出错,因为无法通过方法调用转换将实际参数int转换为String
//因为编译器会根据实参推断类型形参的值,所以系统都可以判断出最直接的类型参数为String
//C.add(58);
泛型Test.show(C);
泛型Test.show2(C);
Collection d = new HashSet();
//由于java在设计集合时,并不知道我们用它来保存什么类型的对象,所以便设计成可以保存任
//何类型的对象。同时也带了问题,集合只是知道它装了Object类型的值,取出元素时还需要进
//行强制类型转换,增加了编程复杂度,也容易引发ClassCastException。下面两行代码中添加
//两种不同类型的元素,没有错误。
d.add(2);
d.add("第二个元素");
泛型Test.show(d);
泛型Test.show2(d);
}
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询