对象数组 - 空指针异常

mea*_*ame -2 java oop nullpointerexception

我需要一个返回对象数组的方法.下面是我的代码,但我得到空指针异常,不知道为什么.

    public Place[] getPlaces() 
    {
        Place result[] = null ;
        int counter = 0;

        try {
            PreparedStatement ps = this.db.prepareStatement("select * from places");

            ResultSet rs = ps.executeQuery();

            while(rs.next()) {
                Place p = new Place();
                p.setPlaceID(rs.getInt("placeID"));
                p.setPlaceName(rs.getString("placeName"));

                result[counter] = p;
                counter++;
            }

        } catch (Exception e) {
            e.printStackTrace();
        }
        return result;
    }
Run Code Online (Sandbox Code Playgroud)

在线result[counter] = p;日食说:

此行的多个标记 - 空指针访问:变量结果在此位置只能为null

所以,我@SuppressWarnings("null")在我的方法之前添加了.但是,当调用方法时,它会抛出空指针异常.在我遇到麻烦之前,尝试打印存储在db中的地名并且它有效.因此,这不是数据库问题,因为错误输出说:

java.lang.NullPointerException
    at PlaceMod.getPlaces(PlaceMod.java:29)
    at PlaceCont.list(PlaceCont.java:15)
    at Main.main(Main.java:14)
Run Code Online (Sandbox Code Playgroud)

这段代码有什么问题?

asg*_*oth 5

您创建了一个空数组.使用ArrayList(因为你不知道结果集的大小):

 List<Place> result = new ArrayList<>();

 while(rs.next()) {
   ...
   result.add(p);
 }
Run Code Online (Sandbox Code Playgroud)