在Android中实现Sensor Event时出现OutofMemoryException?

问题描述

| 我在活动中执行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);
}
我认为这与传感器侦听器无关。     

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...