这一章节我们来讨论一下泛型方法的使用。
泛型除了可以作用在类、接口上面,还可以作用在方法上面。
1.例子
package com.ray.ch13;
public class Test {
public <T> void test(T x) {
System.out.println(x.getClass().getName());
}
public static void main(String[] args) {
Test test = new Test();
test.test("1");
test.test(1);
test.test(1.0);
}
}
输出:
java.lang.String
java.lang.Integer
java.lang.Double
上面的test方法类似被无限重写的效果。
注意:在void前面需要加上<T>的泛型标识符。
2.可变参数
package com.ray.ch13;
public class Test {
public static <T> void test(T... x) {
for (T item : x) {
System.out.println(item.getClass().getName());
}
}
@SuppressWarnings("unchecked")
public static void main(String[] args) {
test(1, "2", 0.5, 1l, 2f);
}
}
输出:
java.lang.Integer
java.lang.String
java.lang.Double
java.lang.Long
java.lang.Float
从上面的方法可以看出,泛型同样也是支持可变参数的。
3.我们利用上一章节的生成器,来填充一个泛型的容器。
生成器代码:
package com.ray.ch13;
import java.util.Random;
public class MyGenerator implements Generator<Father> {
private Class<?>[] classes = { Sub1.class, Sub2.class, Sub3.class };
private Random random = new Random();
@Override
public Father next() {
Father father = null;
try {
father = (Father) classes[random.nextInt(3)].newInstance();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
return father;
}
}
interface Generator<T> {
T next();
}
class Father {
private static int counter = 0;
private final int id = counter++;
@Override
public String toString() {
return "name:" + getClass().getSimpleName() + " id:" + id;
}
}
class Sub1 extends Father {
}
class Sub2 extends Father {
}
class Sub3 extends Father {
}
测试代码:
/**
*
*/
package com.ray.ch13;
import java.util.ArrayList;
import java.util.Collection;
/**
* @Package:com.ray.ch13
*
* @TODO
*
* @date 2015 12 11
*
* @time 16:25:52
*
* @author JMSCADMIN
*
* @version 1.0
*/
public class Test {
public static Collection<Father> fill(Collection<Father> collection,
Generator<Father> generator, int count) {
for (int i = 0; i < count; i++) {
collection.add(generator.next());
}
return collection;
}
public static void main(String[] args) {
Collection<Father> collection = fill(new ArrayList<Father>(),
new MyGenerator(), 5);
for (Father father : collection) {
System.out.println(father);
}
}
}
输出:
name:Sub2 id:0
name:Sub3 id:1
name:Sub3 id:2
name:Sub1 id:3
name:Sub3 id:4
总结:这一章节主要展示了泛型方法的使用。
这一章节就到这里,谢谢。
-----------------------------------
目录
分享到:
相关推荐
Java 泛型编程是Java语言在JDK 1.5版本引入的一项重要特性,它极大地提高了代码的安全性和可重用性。泛型本质上是参数化类型,允许我们在编写代码时,将数据类型作为参数,这使得类、接口和方法能够处理多种不同的...
泛型,即参数化类型(Parameterized Types),是允许在定义类、接口和方法时使用类型参数的特性。在创建类、接口或方法的时候,可以用一个或多个类型作为参数。泛型的关键在于类型参数化,这意味着可以将操作的数据...
在C#中,我们通过在类、接口、方法或委托声明中使用尖括号()来定义泛型。类型参数是泛型中的占位符,代表一个未指定的具体类型。例如,下面是一个简单的泛型方法定义: ```csharp public T Swap(T a, T b) { T ...
日常笔记-JAVA泛型
这种参数类型可以用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法。 Java语言引入泛型的好处是安全简单。 在Java SE 1.5之前,没有泛型的情况的下,通过对类型Object的引用来实现参数的“任意化”...
在Java中,泛型是通过在类、接口或方法声明中使用类型参数来实现的。这使得开发者能够限制容器只能存储特定类型的数据,避免了不必要的类型转换和潜在的ClassCastException。 泛型的主要优点包括: 1. **类型安全*...
而不是创建一个Object列表,你可以参数化java.util.List来创建一个String String列表,如下所示:当通过反射在运行时检查可参数化类型本
泛型是Java 5引入的新特性,它允许在类、接口和方法中使用类型参数,增强了类型安全性和代码重用。泛型可以避免类型转换的麻烦,防止在集合操作中插入不兼容的对象,同时在编译时就能捕获潜在的类型错误。例如,...
下面我们将深入探讨Java泛型方法的概念、语法以及使用示例。 **一、泛型方法概念** 泛型方法是一种具有类型参数的方法,这些类型参数可以在方法声明时指定,并在方法体内部使用。与类的泛型类似,它们提供了编译时...
泛型是Java编程中的一个重要概念,它提供了一种在编译时期检查类型安全性的机制,同时也减少了强制类型转换的需要。泛型主要应用于类、接口和方法中,用来限制可以存储或处理的数据类型。 1. **泛型的意义**: - ...
超全面javaweb教程第7天-_07_泛型方法和泛型类的使用
试用java.util.Stack泛型栈作为父类,用另一个泛型栈对象作为成员变量,模拟实现一个泛型子类Queue,当存储元素的第1个栈的元素超过dump时,再有元素入队列就倒入第2栈。除提供无参构造函数Queue( )外,其它所有队列...
在Java编程语言中,泛型(Generic)是一个强大的特性,它允许我们在编译时检查类型安全,并且可以消除运行时的类型转换。黑马程序员提供的这篇关于泛型的学习注意点,结合了源码分析和工具应用,旨在帮助开发者深入...
- `static`方法若要使用泛型能力,必须将其声明为泛型方法。 - 泛型方法的类型参数可以与类的泛型参数相同,但互不影响。 #### 四、类型通配符 类型通配符允许我们编写更灵活的代码。常见的类型通配符包括: - **...
下面将详细解释Java泛型的基本概念、使用方式以及相关的知识点。 1. 泛型的基本概念: - 泛型是一种参数化类型,允许在定义类、接口和方法时使用类型参数,从而创建一种可以适用于多种类型的通用代码。 - 泛型的...
在Java编程语言中,泛型和反射是两个非常重要的特性,它们在软件开发中有着广泛的应用。本篇文章将深入探讨这两个概念以及它们在实际开发中的小运用。 首先,我们来看泛型(Generics)。泛型是在Java SE 5.0引入的...
java-泛型-面试题.docx
【Java基础】泛型方法 - 右撇子 - 博客频道 - CSDN.NET
Java泛型机制详解 Java泛型是Java语言中的一种机制,用于在编译期检查类型安全。Java泛型的出现解决了Java早期版本中类型安全检查的缺陷。Java泛型的好处是可以在编译期检查类型安全,避免了运行时的...