3

我只是想弄清楚我为什么会出错的逻辑。我第一次尝试在 1 中添加 2 个显示并使用 commandListener 切换视图。我从逻辑上认为我做的一切都是正确的,但我得到了一个空指针异常。我从不想知道答案,我喜欢努力工作,所以如果有人可以问我一个关于我正在努力实现的目标的问题,我可能会根据你的线索或提示来思考答案。将不胜感激。

import java.io.*;
import javax.microedition.midlet.*;
import javax.microedition.lcdui.*;


public class ClassApp extends MIDlet implements CommandListener {
    private Display mydisplay;

    private TextBox d;
    private Alert alert;
    private Command c,e,f,mNextCommand,l;
    private List mList;

    public ClassApp(){

        alert = new Alert("Listen", "Do you really want to start this app?", null, null);
        alert.setTimeout(Alert.FOREVER);

        c = new Command("Exit", Command.EXIT, 2);
        e = new Command("Back", Command.BACK, 0);
        f = new Command("Alert", Command.SCREEN, 3);
        mNextCommand = new Command("Next", Command.SCREEN, 4);
        l = new Command("List", Command.SCREEN, 3);


        d = new TextBox("ClassApp", "Commander", 20, TextField.ANY | TextField.PASSWORD); 
        d.addCommand(c);
        d.addCommand(e);
        d.addCommand(f);
        d.addCommand(l);
        d.setCommandListener(this);
        mList.addCommand(mNextCommand);
        mList.setCommandListener(this);


        String[] stringElements = { "Airplane", "Car", "Hotel" };
        Image[] imageElements = { loadImage("/airplane.png"),
        loadImage("/car.png"), loadImage("/hotel.png") };

        mList = new List("Reservation type", List.IMPLICIT,
        stringElements, imageElements);




    }
    public void startApp() 
    {

        mydisplay = Display.getDisplay(this);
        mydisplay.setCurrent(d);

    }
    public void commandAction(Command j, Displayable s) 
            { 
                if(j == f)
                    mydisplay.setCurrent(alert);
                if(j == l)
                    mydisplay.setCurrent(mList);
                if (j == mNextCommand || j == List.SELECT_COMMAND) {
                int index = mList.getSelectedIndex();
                Alert alert2 = new Alert("Your selection",
                "You chose " + mList.getString(index) + ".",
                null, AlertType.INFO);
                mydisplay = Display.getDisplay(this);
                mydisplay.setCurrent(alert2, mList);
        }

                else if(j == c)
                    notifyDestroyed();
            }





    public void pauseApp() { } 
    public void destroyApp(boolean unconditional) { }
    private Image loadImage(String name) {
        Image image = null;
        try {
        image = Image.createImage(name);
        }
        catch (IOException ioe) {
        System.out.println(ioe);
        }
        return image;
    }
}

我得到的错误是:

Starting emulator in execution mode
Installing suite from: http://127.0.0.1:2913/ClassApp.jad
java.lang.NullPointerException:   0
    at ClassApp.<init>(ClassApp.java:33)
    at java.lang.Class.newInstance(), bci=0
    at com.sun.midp.main.CldcMIDletLoader.newInstance(), bci=46
    at com.sun.midp.midlet.MIDletStateHandler.createMIDlet(), bci=66
    at com.sun.midp.midlet.MIDletStateHandler.createAndRegisterMIDlet(), bci=17
    at com.sun.midp.midlet.MIDletStateHandler.startSuite(), bci=27
    at com.sun.midp.main.AbstractMIDletSuiteLoader.startSuite(), bci=52
    at com.sun.midp.main.CldcMIDletSuiteLoader.startSuite(), bci=8
    at com.sun.midp.main.AbstractMIDletSuiteLoader.runMIDletSuite(), bci=161
    at com.sun.midp.main.AppIsolateMIDletSuiteLoader.main(), bci=26
4

1 回答 1

2

也许如果有人可以问我一个关于我想要达到的目标的问题,这可以让我使用你的线索或提示来思考答案......

好的,我们开始吧。

ClassApp.java:33错误消息的一部分告诉您 ClassApp.java 中的哪一行代码有问题。旁注神秘的部分ClassApp.<init>告诉您 ClassApp 构造函数中正在发生不好的事情。

如果从顶部数到第 33 行,您可能会发现:

    mList.addCommand(mNextCommand);

现在,如果您寻找mList构造函数内部的处理方式(大约有 20 行要检查),您会发现一个有趣的事实,它将指导您找出那里的错误。


另一件值得记住的调查此类错误的事情是NullPointerException堆栈跟踪顶部显示的名称。它翻译成人类语言为

null在不应该存在的地方存在价值。

这通常表明您可能已经注意到某些变量没有正确分配。


PS。

我将继续寻找更好的效率(比如将代码移动到startapp中)

初始化startApp是一个可靠性问题,而不是效率问题。

有几件事建议在构造函数中初始化,startApp而不是在构造函数中初始化。例如,教程MIDlet Life Cycle -> Execution States中解释了这些内容:“通常,您将使用 startApp() 来分配记录存储、网络连接、UI 组件等......”

据我了解,没有明确的清单可以保证在构造函数中安全初始化的内容。正因为如此,我尝试尽可能多地进行初始化startApp——这样,我就不需要在规范中进行繁琐的检查来检查它是否安全。

于 2012-04-19T16:15:46.663 回答