【发布时间】:2012-10-06 06:40:28
【问题描述】:
所以我正在尝试为通用链表和跳过列表编写程序。我还想在使用接口和超类时使用它,以备将来使用,但我似乎无法弄清楚如何使所有东西与所有泛型类型一起工作。
这是我现在的基本想法:
我的列表 ADT 和所有将扩展的节点类:
public class Node<K extends Comparable<K>> {
K key;
Object data;
...
}
public interface List<T> {
public void insert(T value);
public void delete(T value);
}
还有一个链表的例子:
public class LList<T extends Comparable<T>> implements List<LLNode<T>>
public class LLNode<K extends Comparable<K>> extends Node<K>
我这样做对吗?
编辑:更具体地说,当我尝试制作此类非常基本的实例时遇到问题,例如...
List<String> linkedList = new LList<String>();
List[] lists = {linkedList};
sets[0].insert("cookie");
这给了我一个编译器错误:java.lang.String cannot be cast to project.LLNode
【问题讨论】:
-
是什么让您认为它不正确?您是否有编译器错误或意外行为?
-
我会看看那个线程。我更新了我的编译器错误。
-
如此处所写,
LList<String>不能分配给List<String>,而是List<LLNode<String>>,因此插入调用需要LLNode而不是字符串。 -
我怎样才能重组它以便 LList
工作?
标签: java generics interface comparable