开发者

How is this a nullpointerexception?

开发者 https://www.devze.com 2023-04-10 22:10 出处:网络
I\'m really confused: I\'m simply trying to add the names of each object in an ArrayList to another ArrayList.

I'm really confused: I'm simply trying to add the names of each object in an ArrayList to another ArrayList.

for (int i = 0; i < availableParts.size(); i++) {
    for (int j = 0; j < namesOfIngredients.size(); j++){
         if (availableParts.get(i).getName() != namesOfParts.get(j)){开发者_开发问答
             namesOfParts.add(availableParts.get(i).getName());
         }
    }//middle if statement makes sure there are no repeats
}

EDIT: I realize namesOfIngredients is null. However, I need it to start null -- this is how I am copying over the names. Can this just not be done this way?


Make sure that

  1. both lists availableParts and namesOfIngredients are not null
  2. The list that you're adding elements to (namesOfParts) has been properly initialized with a constructor (is not null).
  3. All elements inside these lists are not null

And remember that String comparison is done with String.equals(). Checking equality (==) on two String objects will only return true if they are the same instance.

As a side note, you could consider using List.contains() in order to find out if a certain part's name is on the namesOfIngredients list. Also, maybe it's a typo, but you should be checking for an IndexOutOfBoundsException at namesOfParts.get(j) in that equality check.


You're trying to look at namesOfParts in the loop itself, but in the definition of the loop you're going to the length of namesOfIngredients. Is one of them null? I bet one is.


Given your edit - how do you declare namesOfIngredients?

It should be

Object namesOfIngredients = new Object(); 

not

Object namesOfIngredients;


availableParts.get(i) is probably null and therefore a getName() call results in a NPE.


We don't know: we can't see how availableParts and namesOfParts are initialized.

But we can tell you how to find out. Add print statements like this:

print "Before I try it"
print availableParts.get(i)
print namesOfParts(availableParts.get(i))
print "done"

when it NPE's you'll see exactly which one did the deed.


You seem to be invoking a number of methods within your loop, without checking that the object on which you are invoking it is NULL or not. It is ALWAYS advisable to do so (especially, if you are not sure about the contract of the object returned by a given method)

So, basically, whenever you do something like object.method() and/or object.method1().method2(), ensure that object and/or object.method1() is NOT NULL before invoking follow-up methods on their return values.

Also, you could break calls in the following manner, to better debug and catch NPEs at the exact location:

Object returnObj = object.method1();
Object anotherReturn = returnObj.method2();
0

精彩评论

暂无评论...
验证码 换一张
取 消