Условие в то время как цикл не работает? - PullRequest
2 голосов
/ 27 ноября 2010
private void Scan(DoublyLinkedList dList) { // T(n) = O(n)
    DNode p1 = dList.getFirst();

    while (p1 != null) {
        DNode p2 = p1.next;
        System.out.println(p1.getElement().toString()); // <--- Here it throws NullPointerException.

        if (p2.next != null) {
            DNode p3 = p2.next;

            if (p3.getElement() != null) {
                boolean b = Determinate.isPointRightSide(p1.getElement(), p2.getElement(),p3.getElement());

                if (b == true) {
                    p1 = p1.next;
                } else {
                    p1.next = p3;
                    p3.prev = p1;
                    dList.remove(p2);
                    p1 = p1.prev;
                }
            } else break;
        }else break;
    }
}

исключение:

run:
Exception in thread "main" java.lang.NullPointerException
X :8.0  Y: 9.0angle0.0lol
        at ConvexHull.GrahamVersion.Scan(GrahamVersion.java:102)
        at ConvexHull.GrahamVersion.grahamScan(GrahamVersion.java:83)
        at ConvexHull.GrahamVersion.<init>(GrahamVersion.java:25)

Выдает NullPointerException на System.out.println(p1.getElement().toString());.Это означает, что он не обращает внимания на условие цикла while?

Ответы [ 2 ]

4 голосов
/ 27 ноября 2010

p1 не null, но p1.getElement() возвращено null.

Удалить вызов toString().Вам это не нужно там в sysout.Затем он просто напечатает null как «ноль».

0 голосов
/ 27 ноября 2010

Условие в цикле while работает .NullPointerException выбрасывается на p1.getElement(), то есть null и поэтому не может быть разыменовано.Если бы p1 было null, строка над ним (p2 = p1.next) потерпела бы неудачу.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...