2

我正在使用 cwac-locpoll,它做得很好。但是,我的一些用户遇到了以下问题

java.lang.RuntimeException: WakeLock under-locked com.commonsware.cwac.locpoll.LocationPoller
at android.os.PowerManager$WakeLock.release(PowerManager.java:339)
at android.os.PowerManager$WakeLock.release(PowerManager.java:299)
at com.commonsware.cwac.locpoll.WakefulThread.onPostExecute(WakefulThread.java:59)
at com.commonsware.cwac.locpoll.LocationPollerService$PollerThread.onPostExecute(LocationPollerService.java:231)
at com.commonsware.cwac.locpoll.WakefulThread.run(WakefulThread.java:93)

这是我的LocationReceiver课程,如您所见,它只是SharedPreferences通过帮助程序类将获得的位置存储在我的应用程序中。

public class LocationReceiver extends BroadcastReceiver {
    private static final String TAG = "LocationReceiver";

    @Override
    public void onReceive(Context context, Intent intent) {
    Bundle b = intent.getExtras();
        Location loc = (Location) b.get(LocationPoller.EXTRA_LOCATION);

        if (loc == null) {
            loc = (Location) b.get(LocationPoller.EXTRA_LASTKNOWN);

            if (loc == null) {
                Log.w(TAG, "Unable to get location. " + intent.getStringExtra(LocationPoller.EXTRA_ERROR));
            } else {
                Log.w(TAG, "Timeout getting location, using previous one " + loc);
            }
        } else {
            Log.i(TAG, "Got location " + loc);
        }

        // save location in preferences
        if (loc != null) {
            PrefsHelper.setLastLocation(loc.getLatitude(), loc.getLongitude());
        }
    }
}

我还使用了一个单独的 cwac-wakefulWakefulIntentService来获取最后一个位置并做一些事情,但它们被设计为独立运行。换句话说:

  1. LocationReceiver由 cwac-locpoll 调用以不时地存储最后一个已知位置SharedPreferences
  2. A WakefulIntentService(独立地)计划获取此位置并对其进行处理。

谢谢!

4

1 回答 1

1

这很可能与您的 无关BroadcastReceiver。我需要更新一些最近的更改以WakefulIntentService更好LocationPoller地处理边缘情况,例如 Android 摆脱服务并稍后将其恢复,这可能会有所帮助。

我已就此提交了一个问题——请跟踪该问题以获取有关何时发布修复程序的说明。鉴于此组件的性质,我需要进行长时间运行的测试,因此可能至少需要 24 小时才能发布补丁。

于 2012-05-04T13:31:56.327 回答