【问题标题】:LocationListener sometimes getting called right after LocationManager.removeUpdates()LocationListener 有时会在 LocationManager.removeUpdates() 之后立即被调用
【发布时间】:2011-10-07 15:21:13
【问题描述】:

我的活动有时会在看不见时崩溃。它使用LocationListener 接收位置更新并将其显示在屏幕上。这是相关代码。

public class MyActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
    }

    @Override
    protected void onStart() {
        super.onStart();
        lm = (LocationManager) getSystemService(LOCATION_SERVICE);
        tv = (TextView) findViewById(R.id.textView1);
        lm.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, listener);
    }

    @Override
    protected void onStop() {
        lm.removeUpdates(listener);
        tv = null;
        lm = null;
        super.onStop();
    }

    private LocationManager lm;
    private TextView tv;
    private final LocationListener listener = new LocationListener() {

        @Override
        public void onLocationChanged(Location location) {
            tv.setText(location.getLatitude() + ", " + location.getLongitude());
        }

        @Override
        public void onProviderDisabled(String provider) {
        }

        @Override
        public void onProviderEnabled(String provider) {
        }

        @Override
        public void onStatusChanged(String provider, int status, Bundle extras) {
        }

    };

}

onLocationChanged() 经常在tvnull 时被调用,立即导致NullPointerException。除了onStop(),我没有将tv 设置为null,根据调试器,活动的mStoppedtrue。我怀疑存在竞争条件,即在活动停止时位置消息在主线程的Handler 上排队。

这种行为似乎没有在任何地方记录。如何防止onLocationChanged()onStop() 之后被调用?

【问题讨论】:

    标签: android android-location android-activity


    【解决方案1】:

    你不能。但您也不需要将变量设置为 null。

    【讨论】:

      【解决方案2】:

      很可能在活动停止之前发送了一些东西,因为它是异步发送到侦听器的。我同意@njzk2,因为您不需要将变量设置为空,您可以在onCreate() 中创建变量。

      但还想补充一点,最好在onResume()onPause() 中请求和删除更新,因为当活动对用户可见时,它位于这些方法之间。您希望尽可能少地使用定位服务。

      另外,与问题无关,但将变量放在顶部更标准(尽管在 Java 中无关紧要)

      【讨论】:

      • 感谢您的洞察力。我来自 C++ 世界,最可见的成员首先出现(公共的,然后是受保护的,然后是私有的)。在 Java 中不清理指针也是一种好习惯吗?在这种情况下,我有额外的负担来确保我在onLocationChanged() 中输入的任何内容都可以随时执行。这似乎与AsyncTask. 有同样的问题
      • Java 的一大优点是垃圾收集器。它是一个 VM 守护进程,负责拾取任何没有指向它们的引用(指针)的对象。实际上,大多数情况下,当您的代码超出范围(即在 if 子句中启动的变量)时,局部变量会自动释放。确保Activity 可以参加活动的另一件事是检查:Finishing()
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2011-11-01
      • 2013-10-12
      • 2021-07-08
      • 2016-10-24
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多