我正在我的活动中实施SensorEventListner
。
我正在进行三项活动SensorEventListner
正在实施以检测摇动。在所有三项活动中,我正在注册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时出错。如果传感器事件未在应用程序中使用,那么正常工作。
我的问题是:
在应用程序中一次又一次地注册和取消注册侦听器时,是否存在与内存相关的任何问题?
是否有任何内存泄漏,如果是,那么如何检测以及可以解决问题的方法是什么?
答案 0 :(得分:1)
错误与Bitmaps而非传感器有关。
答案 1 :(得分:1)
您的问题出在您调用setImageResource的GardenActivity.display()方法中。正是这导致了你的问题。也许检查您正在使用的图像的大小,并减少它。
要证明这是正确的,请在onSensorChanged()方法中注释掉对display()的调用,你会发现它会起作用。因此证明它不是传感器框架的错误,但是你在事件处理程序中正在做的事情导致问题(正如我在之前的评论中提到的那样)。
答案 2 :(得分:0)
我会说你试图在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);
}
我认为这与传感器监听器没有任何关系。