在类的运行上空指针

时间:2013-10-18 12:39:33

标签: java swing

当我运行这个项目时,我得到一个NullPointer。

"Exception in thread "main" java.lang.NullPointerException
    at movieinfo.Swinggui.gui(Swinggui.java:71)
    at movieinfo.Swinggui.main(Swinggui.java:38)
"

在这两行中似乎没有,我正在访问尚未声明的内容。 我试图设置断点和调试来自己解决它,但无济于事。 谢谢你帮助我,我真的不是要求被舀勺。

package movieinfo;

import java.awt.Color;
import java.awt.GridBagConstraints;
import java.awt.GridBagLayout;
import java.awt.List;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.File;
import java.io.IOException;
import java.nio.charset.Charset;
import java.util.ArrayList;
import java.util.Map;
import javax.swing.BorderFactory;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JList;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import javax.swing.JTextField;

import org.apache.commons.io.FileUtils;

import com.json.parsers.JSONParser;
import com.json.parsers.JsonParserFactory;


public class Swinggui {
    private static JButton enter;
    private static JTextField movietext;
    private static JTextArea movieinfo;
    private static JList listofmovies;//converts moviestowatch into gui element.
    private static File textfilemovie; //file which movies marked for watching are saved
    private static java.util.List<String> moviestowatch; //arraylist which is populated by textfilemovie than printed to GUI element.
    public static void main(String[] args) throws IOException
    {
yourMovies();
        gui();
        json();



    }
    public static void gui()
    {
        JFrame maingui = new JFrame("Gui");
        maingui.setLayout(new GridBagLayout());
        GridBagConstraints c = new GridBagConstraints();
        c.fill = GridBagConstraints.VERTICAL;
        enter = new JButton("Enter");
        c.gridx = 2;
        c.gridy = 1;
        maingui.add(enter, c);
        movieinfo = new JTextArea(5,20);
        movieinfo.setBorder(BorderFactory.createMatteBorder(2,2,2,2,Color.red));
        movietext = new JTextField(18);
        c.gridx = 1;
        c.gridy = 1;
        maingui.add(movietext, c);
        final JScrollPane scrolll = new JScrollPane(movieinfo);
        c.gridx = 1;
        c.gridy = 3;
        c.gridwidth = 2;
        maingui.add(scrolll, c);
        final JLabel titlee = new JLabel("Enter movie name below!");
        c.gridx = 1;
        c.gridy = 0;
        maingui.add(titlee, c);
        maingui.setResizable(false);
        maingui.setVisible(true);
        listofmovies = new JList(moviestowatch.toArray());
        c.gridx = 4;
        c.gridy = 3;
        maingui.add(new JScrollPane(listofmovies), c);
        movieinfo.setLineWrap(true);
        movieinfo.setWrapStyleWord(true);
        movieinfo.setEditable(false);
        scrolll.getPreferredSize();
        //pangui.setPreferredSize(new Dimension(300, 150));
        //pangui.add(scrolll, BorderLayout.CENTER);
        //movieinfo.add(scrolll);
        maingui.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        maingui.pack();

    }
    public static void json()
    {
        enter.addActionListener(new ActionListener(){

            private JsonParserFactory factory;
            private JSONParser parser;
            @SuppressWarnings("rawtypes")
            private Map jsonData;

            public void actionPerformed(ActionEvent e)  
            {
                System.out.println(apicall.getMovieInfo(movietext.getText()));
                factory = JsonParserFactory.getInstance();
                parser = factory.newJsonParser();
                jsonData = parser.parseJson(apicall.getMovieInfo(movietext.getText()));
                String Title = (String)jsonData.get("Title");
                String Year = (String)jsonData.get("Year");
                String Plot = (String)jsonData.get("Plot");
                movieinfo.setText("Title: "+Title+"\nYear: "+ Year +"\nPlot: "+Plot);
            }
        });
    }
    public static void yourMovies() throws IOException
    {
        textfilemovie = new File(org.apache.commons.io.FileUtils.getUserDirectory() + "/yourmovies.txt");

        textfilemovie.createNewFile();
        moviestowatch = FileUtils.readLines(textfilemovie);
        while (listofmovies.getSelectedValue().toString()!= null)
        {
            movietext.setText(listofmovies.getSelectedValue().toString());
            enter.doClick();
        }

    }
}

5 个答案:

答案 0 :(得分:9)

你在调用yourMovies()之前调用gui(),所以在使用它之前不要初始化ArrayList。

但这不是重要的事情。不,重要的是您认识到如何自行调试NPE的过程:

  • 检查抛出NPE的行
  • 在该行上找到null的变量
  • 然后搜索回代码,看看当你认为它不应该是为什么它是null。

通常这些错误很容易解决,一旦你知道如何。

您的其他问题包括:

  • 你过度使用静态。您的代码没有“ state ”,没有真正的OOP类,这将限制您扩展和改进代码的能力。唯一的静态方法应该是main方法,这应该只包含设置类并启动它们的代码,就是这样。
  • 您的json代码应该属于自己的类,与GUI类分开。这将允许您独立于完全不相关的代码进行调试和增强。寻找凝聚力和耦合。你希望你的阶级凝聚力很高并且耦合度很低:将相关的东西放在一起,将不相关的东西分开。
  • 你的while循环,while (listofmovies.getSelectedValue().toString()!= null)...在当前位置没有任何意义。在创建,构建和渲染之前,不应该在GUI的按钮上调用doClick()
  • 您的代码在没有计划的情况下被抛在一起。更好的方法是在提交任何代码之前先在纸上写出程序结构。

答案 1 :(得分:3)

  

在这两行中似乎没有,我正在访问那些尚未访问的行   宣布了。

相信JVM。如果它说那条线上有一个NPE,那就是真的。你的“似乎”是一个不好的假设。

  

我尝试设置断点和调试来自行修复,拒绝   果。

听起来你需要学习如何在IDE中设置断点。如果你正确地做到这一点,那将很快解决它。你在用哪一个?

  

感谢您帮助我,我真的不是要求被舀勺。

不幸的是, 要求被人掏空。

答案 2 :(得分:2)

您的moviestowatch未初始化。

您正在致电yourMovies()初始化moviestowatch

但您正试图访问moviestowatch中的gui()

答案 3 :(得分:2)

您已在第35行声明了moviestowatch

private static java.util.List<String> moviestowatch; //arraylist which is populated by textfilemovie than printed to GUI element.

并在函数gui()

的第71行使用它
    listofmovies = new JList(moviestowatch.toArray());

在使用之前初始化它。

调用函数的序列是

  gui();
  json();
  yourMovies();

你的列表正在yourMovies()方法中初始化。你正在gui()方法中使用它。所以在调用实际使用它的gui()方法之前调用yourMovies()方法。

修改

你的下一个错误是在以下while循环中得到一个nullpointer @ line 115。

要解决上述错误,您所做的就是更改序列并在gui()之前调用yourMovies()。但是你在这里初始化了gui中的listofmovies列表并在yourMovies()方法中使用:)。

通用编程实践,对于所有列表/对象,您必须在使用之前每次手动检查。它应该在使用之前初始化。否则会抛出NPE。

答案 4 :(得分:-2)

如果你得到NullPointerException,它总是意味着你的一个类字段没有被初始化。你无法使用本地参考变量获得NPE,因为编译器会警告你。我自己尝试初始化所有不需要额外输入的东西,我宣布它并且这种做法为我节省了大量的NPE。这对容器尤其有用。