代码如下:
public class User {
public List<Monster> allMonsters;
public User throws ParseException, IOException, JSONException{
public class User {
public List<Monster> allMonsters;
public User throws ParseException, IOException, JSONException{
Monster monster;
for(int i=0;i<UserMonsterList.length();i++){
monster=new Monster(UserMonsterList.getString(i));
try{
this.allMonsters.add(monster);
}
catch (Exception e)
{
Log.v("e",e.toString());
}
}
}
}
这是一个类的实例化方法的一部分, allMonsters是这个类的一个属性,描述了一个用户对应的一组怪物。
执行后显示错误信息如下:
}
}
这是一个类的实例化方法的一部分,
执行后显示错误信息如下:
E/AndroidRuntime(566): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.aa/com.aa.XXX}: java.lang.NullPointerException
编译通过,执行时日志显示如上错误,这是一个标准的未实例化错误,可是并没有指出错误具体位置.网上G了一下,终于找到原因,参照:http://stackoverflow.com/questions/8200074/android-list-nullpointerexception
原来List的add方法前,必须对object进行实例化,其实就是new一个ArrayList实例,
即将public List<Monster> allMonsters;改为public List<Monster> allMonsters =new ArrayList<Monster>();
问题解决。
总结以上问题,其实,编程习惯还是很重要,严格来说,定义ArrayList时候都需要对其进行初始化,如果遵守这条,就不会出现这问题,还有一点,就是try是一个很好避免查不到问题源的好方法。另一方面来说,android对于错误的检查还不是很完善,一些提示并不明确,也许有些是因为继承了JAVA的缘故。所以,写一点代码,测试一点还是必要的,避免大量代码测试时候无法定位问题源。
即将public List<Monster> allMonsters;改为public List<Monster> allMonsters =new ArrayList<Monster>();
问题解决。