android - 无法破坏 Android Activity

标签 android android-activity jmdns

我收到错误消息,指出该应用无法销毁该 Activity

private JMDNSService jmdnsService = null;

@Override
public void onDestroy() {
    super.onDestroy();
    jmdnsService = null; // destroy this object so we don't keep polling.
    if (D) {Log.i(TAG, "++++ ON DESTROY +++++"); }
    try {
        stopJMDNS();
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    stopWifi();
}

private void stopWifi() { 
    WifiManager wifi = (WifiManager) getSystemService(Context.WIFI_SERVICE);
    wifi.setWifiEnabled(false);
}

private void stopJMDNS() throws IOException { 
    jmdnsService.shutDownJmDNS();
}

来自 JMDNSService.java 的代码:

public boolean shutDownJmDNS(){
if(jmdns != null){
    try {
        jmdns.close();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            return false;
        }
        return true;
    }
    return false;
}

这是它产生的输出的 logcat:

01-11 19:19:54.528: E/AndroidRuntime(754): FATAL EXCEPTION: main
01-11 19:19:54.528: E/AndroidRuntime(754): java.lang.RuntimeException: Unable to destroy activity {com.whooznear.android/com.whooznear.android.WhoozNearActivity}: java.lang.NullPointerException
01-11 19:19:54.528: E/AndroidRuntime(754):  at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:2950)
01-11 19:19:54.528: E/AndroidRuntime(754):  at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:2968)
01-11 19:19:54.528: E/AndroidRuntime(754):  at android.app.ActivityThread.access$1100(ActivityThread.java:122)
01-11 19:19:54.528: E/AndroidRuntime(754):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1057)
01-11 19:19:54.528: E/AndroidRuntime(754):  at android.os.Handler.dispatchMessage(Handler.java:99)
01-11 19:19:54.528: E/AndroidRuntime(754):  at android.os.Looper.loop(Looper.java:132)
01-11 19:19:54.528: E/AndroidRuntime(754):  at android.app.ActivityThread.main(ActivityThread.java:4123)
01-11 19:19:54.528: E/AndroidRuntime(754):  at java.lang.reflect.Method.invokeNative(Native Method)
01-11 19:19:54.528: E/AndroidRuntime(754):  at java.lang.reflect.Method.invoke(Method.java:491)
01-11 19:19:54.528: E/AndroidRuntime(754):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
01-11 19:19:54.528: E/AndroidRuntime(754):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
01-11 19:19:54.528: E/AndroidRuntime(754):  at dalvik.system.NativeStart.main(Native Method)
01-11 19:19:54.528: E/AndroidRuntime(754): Caused by: java.lang.NullPointerException
01-11 19:19:54.528: E/AndroidRuntime(754):  at com.whooznear.android.WhoozNearActivity.stopJMDNS(WhoozNearActivity.java:488)
01-11 19:19:54.528: E/AndroidRuntime(754):  at com.whooznear.android.WhoozNearActivity.onDestroy(WhoozNearActivity.java:447)
01-11 19:19:54.528: E/AndroidRuntime(754):  at android.app.Activity.performDestroy(Activity.java:4561)
01-11 19:19:54.528: E/AndroidRuntime(754):  at android.app.Instrumentation.callActivityOnDestroy(Instrumentation.java:1078)
01-11 19:19:54.528: E/AndroidRuntime(754):  at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:2937)
01-11 19:19:54.528: E/AndroidRuntime(754):  ... 11 more

出于某种原因,它不会让我破坏我的 Activity ?任何想法都会有所帮助。

最佳答案

:-D

 jmdnsService = null;

之后的几行:

 jmdnsService.shutDownJmDNS();

您真的需要更多解释吗?

关于android - 无法破坏 Android Activity ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8825572/

相关文章:

android - Kotlin:不能将null强制转换为非null类型com.google.android.youtube.player.YouTubePlayerFragment

android - Flutter Plugin 使用 Kotlin,Activity 总是返回 null

java - Gstreamer 还是 VLC?对于桌面和移动平台?

android: 方法 Split 可以返回空值吗?

Android 仪器测试 - 使用 OkHttp MockServer.useHttps(...) 时出现 SSLHandshakeException

android - 如何在 Activity 开始时等待服务

android - 锁定安卓设备的 Activity

java - Bonjour 服务在 Equinox 中使用 JmDNS 发布,但在 Apache Felix 中没有发布

android - Android-> iOS零配置网络发现jmDNS损坏

android - 在 Eclipse : Wifistatemachine errors 中使用 JmDNS 进行服务发现