K和int Java之间不兼容的操作数类型

时间:2014-11-02 18:22:09

标签: java

我正在制作一个线性探测碰撞的哈希表。我试图将哈希表的元素添加到Set或Collection。我设置哈希表的方式是它是一个包含泛型类型K的“密钥”和泛型类型V的“值”的节点数组。表中没有数组中的节点的索引是null,但最初有一个节点但被删除的索引标有一个包含新节点(-1,-1)的节点。当我去打印哈希表时,我想避免打印删除的点(包含键-1的索引)。以下是相关代码:

添加到集合或集合的方法(在散列表类中)

@Override
    public Set<K> keySet() {
        Set<K> s = new HashSet<K>();
        for(int i=0; i<this.hashtable.length; i++) {
            if(this.hashtable[i] != null && this.hashtable[i].key != -1)
                s.add(this.hashtable[i].key);
        }
        return s;
    }

    @Override
    public Collection<V> values() {
        LinkedList<V> l = new LinkedList<V>();
        for(int i=0; i<this.hashtable.length; i++) {
            if(this.hashtable[i] != null && this.hashtable[i].key != -1)
                l.add(this.hashtable[i].val);
        }
        return l;
    }

Node类(非散列表类):

private final class Node<K extends Comparable<? super K>, V>  {
        public K key;
        public V val;

        public Node() {
            this.key = null;
            this.val = null;
        }

        public Node(K theKey, V theValue) {
            this.key = theKey;
            this.val = theValue;
        }
    }

实际哈希表类中的主要方法:

public static void main(String[] args) {
        MyJHUHashMap<Integer, String> m = new MyJHUHashMap<>();
        m.put(1, "1!");
        m.put(2, "2!");
        m.put(3, "3!");
        m.put(4, "4!");
        m.put(5, "5!");
        m.put(6, "6!");
        m.put(7, "7!");
        m.put(8, "8!");
        m.put(9, "9!");
        m.put(10, "10!");
        m.put(11, "11!");
        m.put(12, "12!");
        m.put(13, "6!");
        m.put(14, "7!");
        m.put(15, "8!");
        m.put(16, "9!");
        m.put(17, "10!");
        m.put(18, "11!");
        m.put(19, "12!");
        m.put(20, "10!");
        m.put(21, "11!");
        m.put(22, "12!");
        m.put(23, "23!");
        System.out.println(m.get(4));
        System.out.println(m.get(12));
        System.out.println(m.get(25));
        System.out.println(m.containsKey(22));
        System.out.println(m.containsKey(35));
        m.remove(23);
        m.remove(18);
        //m.put(7, 7);
        System.out.println(m.hashtable.length);
        System.out.println(m.size());
        for(int i=0; i<m.hashtable.length; i++) {
            if(m.hashtable[i] != null && m.hashtable[i].key != -1)
                System.out.print(m.hashtable[i].key + " ");
        }
    }

长度似乎正确,大小似乎正确,并且键打印出来,但是,包括-1值。为了解决这个问题,我在方法中写了“this.hashtable [i] .key!= -1”。但是,我在keySet()和values()方法中得到错误“不兼容的操作数类型K和int”,但在main方法中没有。任何人都可以指出如何克服这个问题吗?

1 个答案:

答案 0 :(得分:2)

不要将-1用作“特殊键值”,因为您的键必须是K类型(K可以是任何东西:字符串,日期等)。

请改用null。