Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

"Something wrong here, didn't expect PACKAGE to be resumed" error in android Logcat

Tags:

I have an Android app modeled after the LunarLander example by Google. I am debugging it on a real device, (Motorola Droid) with Android 2.0. When the orientation changes, the program crashes on a NullPointerException. Logcat from just before crash:

02-01 00:24:27.956: DEBUG/nate(8358): Starting Game
02-01 00:24:36.878: DEBUG/dalvikvm(1086): GC freed 1788 objects / 92256 bytes in 1389ms
02-01 00:24:38.542: INFO/WindowManager(1021): Setting rotation to 1, animFlags=0
02-01 00:24:38.558: INFO/ActivityManager(1021): Config changed: { scale=1.0 imsi=310/4 loc=en_US touch=3 keys=2/1/2 nav=2/2 orien=2 layout=34}
02-01 00:24:38.620: WARN/UsageStats(1021): Something wrong here, didnt expect org.nifong.leeder to be resumed
02-01 00:24:38.886: DEBUG/nate(8358): New Surface dimensions: 854x442
02-01 00:24:38.886: DEBUG/nate(8358): flies was null

The first line that worries me is "Something wrong here" at 24:38.620. I have no idea what it means, but I think its due to me not reacting properly to the screen change.

Next I get a debug message that I printed myself from within my own method surfaceChanged() about the new surface dimensions.

Then I print out debug message about whether flies was null. flies is the field that eventually causes the NullPointerException. Its created once, and never written to again for the rest of the program. I know that it was not null before the crash, because it was read several times.

Does anyone have a clue how my private member variable came to be null just by these clues?

I would include code but there is a lot of it and I don't know what would be relevant.

like image 660
Nathan Avatar asked Feb 01 '10 05:02

Nathan


1 Answers

Orientation changes in Android affect state. Basically, your activity is destroyed and recreated. You must therefore be aware of what Android lifecycle events will be called and how to save state.

You also need to be wary of static instances and how that affects this lifecycle.

Here is a blog post explaining some of this.

like image 194
JRL Avatar answered Nov 15 '22 06:11

JRL