1

I have wrote an app with custom Application class (MyApplication.java) and a BroadcastReceiver class (ConnectivityReceiver.java).

However, I sometimes get bug reports from users stated that

java.lang.RuntimeException: Unable to start receiver my.package.background.ConnectivityReceiver: 
java.lang.RuntimeException: Unable to create application my.package.MyApplication: 

I don't know why this exception is showing up.

Here is the detail stack trace and related files.

StackTrace

java.lang.RuntimeException: Unable to start receiver my.package.background.ConnectivityReceiver: 
java.lang.RuntimeException: Unable to create application my.package.MyApplication: 
java.lang.NullPointerException
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2287)
at android.app.ActivityThread.access$1600(ActivityThread.java:140)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1313)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4921)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1038)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:805)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.RuntimeException: Unable to create application my.package.MyApplication: java.lang.NullPointerException
at android.app.LoadedApk.makeApplication(LoadedApk.java:514)
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2267)
... 10 more
Caused by: java.lang.NullPointerException
at my.package.MyApplication.setLanguage(MyApplication.java:137)
at my.package.MyApplication.onCreate(MyApplication.java:83)
at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1014)
at android.app.LoadedApk.makeApplication(LoadedApk.java:511)
... 11 more
java.lang.RuntimeException: Unable to create application my.package.MyApplication: java.lang.NullPointerException
at android.app.LoadedApk.makeApplication(LoadedApk.java:514)
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2267)
at android.app.ActivityThread.access$1600(ActivityThread.java:140)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1313)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4921)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1038)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:805)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at my.package.MyApplication.setLanguage(MyApplication.java:137)
at my.package.MyApplication.onCreate(MyApplication.java:83)
at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1014)
at android.app.LoadedApk.makeApplication(LoadedApk.java:511)
... 11 more
java.lang.NullPointerException
at my.package.MyApplication.setLanguage(MyApplication.java:137)
at my.package.MyApplication.onCreate(MyApplication.java:83)
at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1014)
at android.app.LoadedApk.makeApplication(LoadedApk.java:511)
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2267)
at android.app.ActivityThread.access$1600(ActivityThread.java:140)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1313)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4921)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1038)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:805)
at dalvik.system.NativeStart.main(Native Method)

MyApplication.java

public class MyApplication extends Application {

    @Override
    public void onCreate() {
        super.onCreate(); 
        //onCreate(MyApplication.java:83) refer to next line  
        setLanguage();
    }

    private void setLanguage() {       
        //setLanguage(MyApplication.java:137) refer to nextline
        Configuration config = getResources().getConfiguration();
        Log.i("MyApplication", "current language setting is: " + config.locale.getLanguage());    
    }
}

ConnectivityReceiver.java

public class ConnectivityReceiver extends BroadcastReceiver {
    public ConnectivityReceiver() {
    }

    @Override
    public void onReceive(Context context, Intent intent) {
        Log.i(this.getClass().getSimpleName(), "onReceive");
    }
}

AndroidManifest.xml

    ...
    <receiver android:name=".package.background.ConnectivityReceiver">
        <intent-filter>
            <action android:name="android.net.conn.CONNECTIVITY_CHANGE" />
            <action android:name="android.net.wifi.WIFI_STATE_CHANGED" />
        </intent-filter>
    </receiver>
    ...
Season
  • 1,178
  • 2
  • 22
  • 42

0 Answers0