问题描述
|
我在活动中执行implementing0ѭ。
我正在执行三个活动,其中“ 0”正在实现以检测震动。在所有三个活动中,我分别注册
sensorListner onCreate
和注销listner onPause
。在每次活动调用时,它都会重新注册,然后在onPause上取消注册。
我的应用程序已将堆大小分配为3.6MB,而设备的堆大小为16MB,但由于LogCat中的错误而仍被强制关闭:
\“ OutOfMemoryException:位图大小超出VM预算\”
编辑:Logcat错误
06-13 15:47:35.056: ERROR/AndroidRuntime(10377): Uncaught handler: thread main exiting due to uncaught exception
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): java.lang.OutOfMemoryError: bitmap size exceeds VM budget
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:464)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:340)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at android.graphics.drawable.Drawable.createFromresourceStream(Drawable.java:697)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at android.content.res.Resources.loadDrawable(Resources.java:1705)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at android.content.res.Resources.getDrawable(Resources.java:580)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at android.widget.ImageView.resolveUri(ImageView.java:548)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at android.widget.ImageView.setimageResource(ImageView.java:270)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at com.nga.flashcards.activities.GardenActivity.display(GardenActivity.java:1024)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at com.nga.flashcards.activities.GardenActivity.onSensorChanged(GardenActivity.java:1352)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at android.hardware.SensorManager$ListenerDelegate$1.handleMessage(SensorManager.java:435)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at android.os.Handler.dispatchMessage(Handler.java:99)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at android.os.Looper.loop(Looper.java:123)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at android.app.ActivityThread.main(ActivityThread.java:4595)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at java.lang.reflect.Method.invokeNative(Native Method)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at java.lang.reflect.Method.invoke(Method.java:521)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
06-13 15:47:35.196: ERROR/AndroidRuntime(10377): at dalvik.system.NativeStart.main(Native Method)
我也有大量图像,并通过setimageResource()在imageview中更改图像。使用SensorEventListner时出现错误。如果未在应用程序中使用传感器事件,则工作正常。
我的问题是:
惠特在应用程序中一次又一次注册和注销监听器时,是否存在与内存有关的任何问题?
是否有任何内存泄漏,如果是,则如何检测以及如何解决该问题?
解决方法
您的问题出在您要调用setImageResource的GardenActivity.display()方法中。这是造成您的问题的原因。也许检查您正在使用的图像的大小,然后缩小它。
为了证明这是正确的,请在onSensorChanged()方法中注释掉对display()的调用,然后您会发现它可以正常工作。因此,证明不是错误的传感器框架,而是导致事件发生的事件处理程序中您正在做的事情(正如我在前面的评论中提到的)。
, 错误与位图而非传感器有关。
参见OutOfMemoryError:位图大小超出VM预算:-Android
确保您调用Bitmap.recycle()
检查正在加载的位图的大小
, 我会说您正在尝试在ImageView中加载太大而无法在内存中解码的图像。尝试查看在获取异常时哪个drawable导致错误(在Exception处理代码中使用断点,例如:
resourceId = ...; (here you put the resource ID)
try {
imageView.setImageResource(resourceId);
} catch (Exception e) { // to be removed in production code
Log.d(\"\",\"Failed to load resource: \" + resourceId);
}
我认为这与传感器侦听器无关。