3

不知何故,我在 JDK 1.6.0_14 中遇到了一个空指针异常:

HttpSession session = request.getSession(true);
LinkedList<MyObject> list = (LinkedList<MyObject>) session.getAttribute(MY_LIST_KEY);
....
list.addFirst( new MyObject(str1, str2, map) );

然后,我得到这个:

 at java.util.LinkedList.addBefore(LinkedList.java:779)

这是方法:

private Entry<E> addBefore(E e, Entry<E> entry) {
    Entry<E> newEntry = new Entry<E>(e, entry, entry.previous);
    newEntry.previous.next = newEntry;//this line NPEs
    newEntry.next.previous = newEntry;
    size++;
    modCount++;
    return newEntry;
}

这被称为

public void addFirst(E e) {
    addBefore(e, header.next);
}

是否有任何奇怪的方式可以序列化/反序列化列表以破坏标题条目以导致这种情况发生?我不明白这怎么可能失败。

这是序列化方法LinkedList

private void writeObject(java.io.ObjectOutputStream s)
    throws java.io.IOException {
    // Write out any hidden serialization magic
    s.defaultWriteObject();

    // Write out size
    s.writeInt(size);

    // Write out all elements in the proper order.
    for (Entry e = header.next; e != header; e = e.next)
        s.writeObject(e.element);
}

private void readObject(java.io.ObjectInputStream s)
    throws java.io.IOException, ClassNotFoundException {
    // Read in any hidden serialization magic
    s.defaultReadObject();

    // Read in size
    int size = s.readInt();

    // Initialize header
    header = new Entry<E>(null, null, null);
    header.next = header.previous = header;

    // Read in all elements in the proper order.
    for (int i=0; i<size; i++)
        addBefore((E)s.readObject(), header);
}
4

2 回答 2

2

我的猜测是跨多个线程不正确地共享列表。我猜这个列表正在同时被两个不同的线程修改。

于 2010-10-25T16:59:30.473 回答
-2

很可能,(LinkedList<MyObject>) session.getAttribute(MY_LIST_KEY)返回null
更新:正如评论中正确指出的那样,这里null不能返回getAttribute(),否则 stacktrace 不会指向LinkedList. 所以,我的建议是错误的。

于 2010-10-25T15:29:52.097 回答