在这里坚持了好几天....这里有什么问题请告诉
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();
}
}
答案 0 :(得分:2)
看起来你的代码在这一行出错了
p1.add(l[i]);
你在哪里初始化你的数组l?此外,您只需设置该数组的前n个记录,其中n是ResultSet中的行数。但是后来你添加了数组的前500个元素。您是否从SQL查询中获得至少500个元素?