【问题标题】:The method compareTo(Comparable) is undefined for the type Comparable未定义 Comparable 类型的 compareTo(Comparable) 方法
【发布时间】:2021-05-17 13:21:54
【问题描述】:

所以我正在构建一个库作为项目,它不涵盖所有数据结构,而是涵盖大部分数据结构,我发现自己遇到了这个问题:

package structure.tree;

import structure.Structure;
import structure.node.BinaryNodeKeyValue;

public class AVLTree<Comparable,V> extends Tree<BinaryNodeKeyValue<Comparable,V>> {
    
    private static final long serialVersionUID = 5046115177325966348L;

    public AVLTree(){

    }

    @Override
    public int compareTo(Structure<BinaryNodeKeyValue<Comparable,V>> o) {
        // TODO Auto-generated method stub
        return 0;
    }

    @Override
    public boolean containsValue(BinaryNodeKeyValue<Comparable,V> elem) {
        return containsValueAux(((BinaryNodeKeyValue<Comparable,V>) super.getValue()), elem);
    }

    private boolean containsValueAux(BinaryNodeKeyValue<Comparable,V> root, BinaryNodeKeyValue<Comparable,V> elem){
        if(root == null) return false;
        else {
            if(root.equals(elem)) return true;
            else return containsValueAux(root.getLeft(), elem) || containsValueAux(root.getRight(), elem);
        }
    }

    public boolean containsKey(Comparable key){
        return containsKeyAux(((BinaryNodeKeyValue<Comparable,V>) super.getValue()), key);
    }

    private boolean containsKeyAux(BinaryNodeKeyValue<Comparable,V> root, Comparable key){
        if(root == null) return false;
        else {
            if(root.getKey().compareTo(key) > 0) return containsKeyAux(root.getRight(), key);
            else if(root.getKey().compareTo(key) < 0) return containsKeyAux(root.getLeft(), key);
            else return true;
        }
    }

    @Override
    public void deleteValue(BinaryNodeKeyValue<Comparable,V> elem) {
        // TODO Auto-generated method stub

    }
    
    @Override
    public void insertValue(BinaryNodeKeyValue<Comparable,V> elem) {
        // TODO Auto-generated method stub

    }

    @Override
    public BinaryNodeKeyValue<Comparable,V>[] toArray() {
        // TODO Auto-generated method stub
        return null;
    }

    public BinaryNodeKeyValue<Comparable,V> get(BinaryNodeKeyValue<Comparable,V> root, Comparable key){
        return getAux(root, key);
    }

    private BinaryNodeKeyValue<Comparable, V> getAux(BinaryNodeKeyValue<Comparable, V> root, Comparable key) {
        return null;
    }

}

在第 40 行和第 41 行(方法 containsKeyAux 的第 3 行和第 4 行)它说“Comparable 类型的方法 compareTo(Comparable) 是未定义的”,这让我大吃一惊,因为方法 compareTo 实际上只在 Comparable 接口中定义。 VS Code 还在第 6 行向我显示了一条警告,上面写着“类型参数 Comparable 隐藏了 Comparable 类型”,但我试图使 Comparable 类型尽可能通用,因为节点的键可能是字符串、整数或不同类型的对象。

【问题讨论】:

    标签: java oop inheritance tree abstraction


    【解决方案1】:

    当你声明一个像 AVLTree&lt;Comparable,V&gt; 这样的泛型时,你创建了一个具有两个泛型类型 Comparable 和 V 的类,而 Comparable 与接口 Comparable 无关,它们只是碰巧有相同的名称。

    你可能是说

    class AVLTree<T extends Comparable, V>
    

    【讨论】:

    • 非常感谢!我今天学到了一个新东西(我还是个大学生,我现在正在学习这些东西)
    最近更新 更多