mouseMoved给出null异常指针 - 完全莫名其妙(更多斯坦福CS106痛苦)

时间:2012-07-22 22:46:37

标签: java nullpointerexception runtime-error

我完成了这项练习:

import acm.program.*;
import acm.graphics.*;
import java.awt.event.*;
public class ProgramHierarchy extends GraphicsProgram {
public void run() {
    Paddle = new GRect(0,getHeight() - 30,100,20);
    add(Paddle);
    addMouseListeners();
    }

public void mouseMoved(MouseEvent e) {
    if(e.getX() - Paddle.getWidth()>0) {
    Paddle.move(e.getX()-Paddle.getX()-Paddle.getWidth(), 0);
    }
}

private GRect Paddle;
}

但是当我在一个更大的项目中使用完全相同的代码时,我的eclipse会抛出空指针异常甚至硬崩溃完全消失,我打我的桌子说坏话我不喜欢我的一家人听。我的eclipse副本是否腐败?会发生什么事?

这是我的大型硬碰撞项目。

import acm.graphics.*;
import acm.program.*;
import acm.util.*;
import java.applet.*;
import java.awt.*;
import java.awt.event.*;

public class Breakout extends GraphicsProgram {

public static final int APPLICATION_WIDTH = 400;
public static final int APPLICATION_HEIGHT = 600;
private static final int WIDTH = APPLICATION_WIDTH;
private static final int HEIGHT = APPLICATION_HEIGHT;
private static final int PADDLE_WIDTH = 60;
private static final int PADDLE_HEIGHT = 10;
private static final int PADDLE_Y_OFFSET = 30;
private static final int NBRICKS_PER_ROW = 10;
private static final int NBRICK_ROWS = 10;
private static final int BRICK_SEP = 3;
private static final int BRICK_WIDTH =
  (WIDTH - (NBRICKS_PER_ROW - 1) * BRICK_SEP) / NBRICKS_PER_ROW;
private static final int BRICK_HEIGHT = 8;
private static final int BALL_RADIUS = 10;
private static final int BRICK_Y_OFFSET = 70;
private static final int NTURNS = 3;
private static final int DELAY = 30;



public void run() {
    setup();
    GRect Paddle = new GRect(0,HEIGHT - PADDLE_HEIGHT - PADDLE_Y_OFFSET,PADDLE_WIDTH,PADDLE_HEIGHT);
    add(Paddle);
    addMouseListeners();
    }







private void setup() {

    int xStart = (WIDTH - ((NBRICKS_PER_ROW * BRICK_WIDTH) + ((NBRICKS_PER_ROW -1) * BRICK_SEP)))/2;

    int y = BRICK_Y_OFFSET;

    for (int i = 0; i< NBRICK_ROWS; i++) {
        int x = xStart;

        for (int j = 0; j < NBRICKS_PER_ROW; j++) {
            GRect block = new GRect(x, y, BRICK_WIDTH, BRICK_HEIGHT);
            if (i<2) {
                block.setColor(Color.RED);
                block.setFilled(true);
                block.setFillColor(Color.red);
            }
            if (i==2||i==3) {
                block.setColor(Color.orange);
                block.setFilled(true);
                block.setFillColor(Color.orange);
            }
            if (i==4||i==5) {
                block.setColor(Color.yellow);
                block.setFilled(true);
                block.setFillColor(Color.yellow);
            }
            if (i==6||i==7) {
                block.setColor(Color.green);
                block.setFilled(true);
                block.setFillColor(Color.green);
            }
            if (i==8||i==9) {
                block.setColor(Color.cyan);
                block.setFilled(true);
                block.setFillColor(Color.cyan);
            }
            add (block);
            x=x+BRICK_WIDTH + BRICK_SEP;
        }
    y=y+BRICK_HEIGHT+BRICK_SEP;
    }
}


public void mouseMoved(MouseEvent PadX) {
    if(PadX.getX() - Paddle.getWidth()>0) {
    Paddle.move(PadX.getX()-Paddle.getX()-Paddle.getWidth(), 0);
    }
}


private GRect Paddle;
}

1 个答案:

答案 0 :(得分:4)

你正在遮蔽Paddle变量:在类中声明它,但在run方法中重新声明它。类中保存的Paddle变量从不初始化,因此它保持为null。解决方案是不在run方法中重新声明此变量。

例如,在您的代码中,您有:

public void run() {
  Paddle = new GRect(0,getHeight() - 30,100,20); // **** notice the difference?
  add(Paddle);
  addMouseListeners();
}

并且在不起作用的代码中:

public void run() {
  setup();

  // notice that you re-declare Paddle here!
  GRect Paddle = new GRect(0,HEIGHT - PADDLE_HEIGHT - PADDLE_Y_OFFSET,PADDLE_WIDTH,PADDLE_HEIGHT);
  add(Paddle);
  addMouseListeners();
}

上面初始化的Paddle变量只在run方法中可见,而在类中没有其他位置。具有相同名称的类变量保持为空。

解决方案:不要重新声明Paddle:

public void run() {
  setup();

  // Now we don't re-declare Paddle 
  Paddle = new GRect(0,HEIGHT - PADDLE_HEIGHT - PADDLE_Y_OFFSET,PADDLE_WIDTH,PADDLE_HEIGHT);
  add(Paddle);
  addMouseListeners();
}