在android中实现传感器事件时出现OutofMemoryException?

时间:2011-06-13 07:09:33

标签: android sensor

我正在我的活动中实施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时出错。如果传感器事件未在应用程序中使用,那么正常工作。

我的问题是:

  • 在应用程序中一次又一次地注册和取消注册侦听器时,是否存在与内存相关的任何问题?

  • 是否有任何内存泄漏,如果是,那么如何检测以及可以解决问题的方法是什么?

3 个答案:

答案 0 :(得分:1)

错误与Bitmaps而非传感器有关。

  1. 请参阅OutOfMemoryError: bitmap size exceeds VM budget :- Android
  2. 确保调用Bitmap.recycle()
  3. 检查要加载的位图的大小

答案 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);
}

我认为这与传感器监听器没有任何关系。