给出java中抽象参数化的例子
时间: 2023-10-20 07:07:20 浏览: 74
抽象类实例
在Java中,抽象参数化通常使用接口(Interface)来实现。接口是一种规范,它定义了一个类应该实现哪些方法以及方法的签名,但不提供方法的具体实现。
以下是一个Java中的抽象参数化的例子,假设我们需要实现一个简单的队列(Queue)数据结构:
```java
public interface Queue<T> {
public void enqueue(T item);
public T dequeue();
public boolean isEmpty();
}
```
这个队列数据结构中,使用了泛型参数 T,它代表了队列中存储的元素类型。这个数据结构也是一个接口,它定义了三个方法:enqueue()、dequeue()、isEmpty()。这些方法的签名已经被定义了,但是具体的实现需要在实现这个接口的类中提供。
我们可以使用这个接口来实现不同的队列数据结构,例如:
```java
public class ArrayQueue<T> implements Queue<T> {
private T[] items;
private int head;
private int tail;
public ArrayQueue(int capacity) {
this.items = (T[]) new Object[capacity];
this.head = 0;
this.tail = 0;
}
public void enqueue(T item) {
if (this.tail == this.items.length) {
throw new IllegalStateException();
}
this.items[this.tail] = item;
this.tail++;
}
public T dequeue() {
if (this.isEmpty()) {
throw new NoSuchElementException();
}
T item = this.items[this.head];
this.head++;
return item;
}
public boolean isEmpty() {
return this.head == this.tail;
}
}
```
这个 ArrayQueue 类实现了 Queue 接口,它使用了泛型参数 T。在这个类中,我们使用数组来存储队列中的元素,实现了 enqueue()、dequeue()、isEmpty() 三个方法。这些方法的签名与 Queue 接口中定义的方法相同,但是具体的实现与队列的实现有关。
我们还可以使用其他的类来实现 Queue 接口,例如 LinkedListQueue 类,它使用链表来存储队列中的元素。这些类都实现了 Queue 接口,但是具体的实现不同。
使用抽象参数化的好处是可以将代码更加通用和可重用,因为不同的类都实现了相同的接口,所以可以在使用时进行替换。
阅读全文