SensorEventListener中的Java android OutOfMemoryError

时间:2017-06-09 07:56:03

标签: java android

我在类中有一个OutOfMemoryError,我在其中实现了一个SensorEventListener。在这里的日志中,有时我有一个OutOfMemoryError

@Override
public void onSensorChanged(SensorEvent event) {
    if (event.sensor.getType() == Sensor.TYPE_ACCELEROMETER) {
        gravity = event.values;
    }
    if (event.sensor.getType() == Sensor.TYPE_MAGNETIC_FIELD) {
        geomagnetic = event.values;
    }
    if (gravity != null && geomagnetic != null) {
        float R[] = new float[9];
        float I[] = new float[9];
        boolean success = SensorManager.getRotationMatrix(R, I, gravity, geomagnetic);
        if (success) {
            float orientation[] = new float[3];
            SensorManager.getOrientation(R, orientation);
            float azimuthInRadians = orientation[0];
            float azimuthInDegress = (float)Math.toDegrees(azimuthInRadians);
            if (azimuthInDegress < 0.0f) {
                azimuthInDegress += 360.0f;
            }
            azimuth = (int) azimuthInDegress;
            Hawk.put(HawkConst.AZIMUTH, azimuth);
        }
    }
}

这是我的日志。有时候我有这个错误但不总是

  at com.android.internal.util.FastXmlSerializer.<init>(FastXmlSerializer.java:55)
   at com.android.internal.util.XmlUtils.writeMapXml(XmlUtils.java:177)
   at android.app.SharedPreferencesImpl.writeToFile(SharedPreferencesImpl.java:596)
   at android.app.SharedPreferencesImpl.access$800(SharedPreferencesImpl.java:52)
   at android.app.SharedPreferencesImpl$2.run(SharedPreferencesImpl.java:511)
   at android.app.SharedPreferencesImpl.enqueueDiskWrite(SharedPreferencesImpl.java:532)
   at android.app.SharedPreferencesImpl.access$100(SharedPreferencesImpl.java:52)
   at android.app.SharedPreferencesImpl$EditorImpl.commit(SharedPreferencesImpl.java:454)
   at com.orhanobut.hawk.SharedPreferencesStorage.put(SharedPreferencesStorage.java:23)
   at com.orhanobut.hawk.Hawk.put(Hawk.java:63)
   at pl.***.****.worker.Tracker.onSensorChanged(Tracker.java:154)
   at android.hardware.SystemSensorManager$SensorEventQueue.dispatchSensorEvent(SystemSensorManager.java:474)
   at android.os.MessageQueue.nativePollOnce(MessageQueue.java)
   at android.os.MessageQueue.next(MessageQueue.java:138)
   at android.os.Looper.loop(Looper.java:131)
   at android.app.ActivityThread.main(ActivityThread.java:5593)
   at java.lang.reflect.Method.invokeNative(Method.java)
   at java.lang.reflect.Method.invoke(Method.java:515)
   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
   at dalvik.system.NativeStart.main(NativeStart.java)

1 个答案:

答案 0 :(得分:1)

您的onSensorChanged()回调似乎正在进行一些繁重的工作。所以在你的回调中你正在调用SharedPreferences。不好的原因是每次传感器有新值时都会调用onSensorChanged(),基于你的监听器配置,这可能会每秒多次发生。这意味着您尝试多次保存到文件(使用共享偏好)。这需要在事物的ororid方面进行大量分配,并可能导致OutOfMemoryError。

为了解决这个问题,我建议将值存储在变量中,并且只在某些固定间隔内执行保存或基于某些事件(按钮点击,生命周期事件等)。

另外我看到你正在使用.commit()阻止线程直到文件被保存,你可以尝试使用.apply(),它将提交动作移动到其他线程。无需担心,您需要限制使用共享偏好的次数。