super.onDestroy(); 应该放在第一行还是放在最后一行?为什么?

本文详细解析了Android Activity生命周期中的onDestroy方法。此方法主要用于释放资源,包括关闭对话框、游标,停止搜索,并通知Application销毁Activity。此外,还介绍了与onDestroy方法调用相关的源码流程。

放在第一行:

@Override
    public void onDestroy() {
        // TODO:  some code
        super.onDestroy();
    }
放在最后一行:

@Override
    public void onDestroy() {
        super.onDestroy();
        // TODO:  some code
    }
onDestroy到底做了那些事情?
看源码:

 protected void onDestroy() { 
    if (DEBUG_LIFECYCLE)  Slog.v(TAG, "onDestroy " + this); 
     mCalled = true; 

    // dismiss any dialogs we are managing.
    if (mManagedDialogs != null) { 
        final int numDialogs = mManagedDialogs.size(); 
        for (int i = 0; i < numDialogs; i++) {
        final ManagedDialog md = mManagedDialogs.valueAt(i); 
        if (md.mDialog.isShowing()) {
            md.mDialog.dismiss(); 
        } 
     } 
       mManagedDialogs = null;
     } 


     // close any cursors we are managing. 
      synchronized (mManagedCursors) {
     int numCursors = mManagedCursors.size(); 
     for (int i = 0; i < numCursors; i++) {
     ManagedCursor c = mManagedCursors.get(i);
     if (c != null) {
       c.mCursor.close();
      } 
     } 
     mManagedCursors.clear(); 
      }


     // Close any open search dialog 
     if (mSearchManager != null) { 
         mSearchManager.stopSearch();
      } 
     if (mActionBar != null) {
         mActionBar.onDestroy(); 
      } 
     getApplication().dispatchActivityDestroyed(this);
      }
继续往下走:android.app.Application#dispatchActivityDestroyed
   /* package */
void dispatchActivityDestroyed(Activity activity) {
Object[] callbacks = collectActivityLifecycleCallbacks();
if (callbacks != null) {
for (int i=0; i<callbacks.length; i++) {
((ActivityLifecycleCallbacks)callbacks[i]).onActivityDestroyed(activity);
}
}
}
继续往下走:
//activity 将从栈中移除
public void onActivityDestroyed(Activity activity) {
LogUtil.d("GIO.AppState", new Object[]{"onActivityDestroyed ", activity});
this.a().remove(activity);
this.t.remove(activity);
this.u.remove(activity);
}
所以在super()后再写操作可能会导致操作对象爆出NullPointerException;(只有一行代码之隔 概率还是很低的,但理论上是存在的)






但是你能不能给我提供一个仅仅有这三个步骤的,别的不做更改? 1 删除 build.gradle 中所有 com.amap.api:* 的远程依赖,只留 .aar 2 给 calculateBusRouteAsyn() 包一层 try-catch (Exception e) 防止编译报错 3 补全 OnRouteSearchListener 的四个方法(即使空实现) 目前代码如下:package com.example.bus; import android.os.Bundle; import android.widget.Toast; import androidx.appcompat.app.AppCompatActivity; import com.amap.api.maps.AMap; import com.amap.api.maps.MapView; import com.amap.api.services.route.BusPath; import com.amap.api.services.route.BusRouteResult; import com.amap.api.services.route.DriveRouteResult; import com.amap.api.services.route.RouteResult; import com.amap.api.services.route.RouteSearch; public class RoutePlanActivity extends AppCompatActivity implements RouteSearch.OnRouteSearchListener { private MapView mapView; private AMap aMap; private RouteSearch routeSearch; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_route_plan); mapView = findViewById(R.id.map_view); mapView.onCreate(savedInstanceState); if (aMap == null) aMap = mapView.getMap(); routeSearch = new RouteSearch(this); routeSearch.setRouteSearchListener(this); parseIntentAndStartSearch(); } private void parseIntentAndStartSearch() { String startMode = getIntent().getStringExtra("start_mode"); double targetLat = getIntent().getDoubleExtra("target_lat", 0); double targetLng = getIntent().getDoubleExtra("target_lng", 0); if (targetLat == 0 || targetLng == 0) { Toast.makeText(this, "目标位置无效", Toast.LENGTH_SHORT).show(); finish(); return; } // 构造目标点 com.amap.api.services.core.LatLonPoint startPoint, targetPoint; if ("my_location".equals(startMode)) { // TODO: 实际应使用定位获取“我的位置” // 这里模拟北京某坐标 startPoint = new com.amap.api.services.core.LatLonPoint(39.909186, 116.397411); } else { double startLat = getIntent().getDoubleExtra("start_lat", 0); double startLng = getIntent().getDoubleExtra("start_lng", 0); startPoint = new com.amap.api.services.core.LatLonPoint(startLat, startLng); } targetPoint = new com.amap.api.services.core.LatLonPoint(targetLat, targetLng); RouteSearch.FromAndTo fromAndTo = new RouteSearch.FromAndTo(startPoint, targetPoint); RouteSearch.BusRouteQuery query = new RouteSearch.BusRouteQuery(fromAndTo, RouteSearch.BUS_DEFAULT, "", 0); routeSearch.calculateBusRouteAsyn(query); } @Override public void onBusRouteSearched(BusRouteResult result, int rCode) { if (rCode == 1000 && result != null && result.getPaths() != null && !result.getPaths().isEmpty()) { BusPath best = result.getPaths().get(0); Toast.makeText(this, "推荐路线:" + best.getDuration() / 60 + "分钟,步行" + best.getWalkDistance() + "米", Toast.LENGTH_LONG).show(); // TODO: 绘制路线(后续可加 Polyline 或 RouteOverlay) } else { Toast.makeText(this, "未找到公交路线", Toast.LENGTH_SHORT).show(); } } @Override public void onDriveRouteSearched(DriveRouteResult result, int rCode) {} @Override protected void onResume() { mapView.onResume(); super.onResume(); } @Override protected void onPause() { mapView.onPause(); super.onPause(); } @Override protected void onDestroy() { mapView.onDestroy(); super.onDestroy(); } @Override protected void onSaveInstanceState(Bundle outState) { mapView.onSaveInstanceState(outState); super.onSaveInstanceState(outState); } } 你提供一份修改过的完整代码
最新发布
11-04
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

闲暇部落

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值