0

卡在这里好几天了....这里有什么问题请告诉

Exception in thread "main" java.lang.NullPointerException
    at java.awt.Container.addImpl(Unknown Source)
    at java.awt.Container.add(Unknown Source)
    at contacts3.<init>(contacts3.java:41)
    at contacts3.main(contacts3.java:75)

我的代码的一部分---

contacts3()
{
    try
    {
        f1=new JFrame();
        Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
        Connection con=DriverManager.getConnection("jdbc:odbc:login321", "", "");
        Statement st=con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_UPDATABLE);
        String fet="Select * from Contacts";
        ResultSet rs=st.executeQuery(fet);
        int i=0;
        while(rs.next())
        {
            l[i]=new JLabel(rs.getString(1));
            l[i].setFont(ft);
            i++;
        }
    }
    catch(Exception e)
    {
        System.out.println("acccc");
        e.printStackTrace();        
    }
    p1.setLayout(new GridLayout(500,1));
    for(int i=0;i<500;i++)
    {
        p1.add(l[i]);
        l[i].addMouseListener(this);
    }

    f1.getContentPane().add(p1);
    f1.setSize(600,300);
    f1.setVisible(true);

}
public void mouseClicked(MouseEvent m)
{
    try
    {
        JLabel label=(JLabel)m.getSource();
        //new convall(label.getText());
        f1.dispose();
    }
    catch(Exception e)
    {
        System.out.println("avc");
        e.printStackTrace();
    }
}
4

1 回答 1

2

看起来您的代码在这一行出错了

p1.add(l[i]);

你在哪里初始化你的数组 l?此外,您只需设置该数组的前 n 条记录,其中 n 是 ResultSet 中的行数。但稍后您添加了数组的前 500 个元素。您是否从 SQL 查询中获得至少 500 个元素?

于 2013-08-06T14:44:51.963 回答