2015-04-05 1 views
1

У меня есть Broadcastreceiver который проверяет CONNECTIVITY_CHANGE и он выходит из строя, иногда с сообщением:ClassNotFoundException - Невозможно создать экземпляр BroadcastReceiver

04-05 18:23:47.080 5561-5561/tenkol.design.com.imbrecords E/AndroidRuntime﹕ FATAL EXCEPTION: main 
java.lang.RuntimeException: Unable to instantiate receiver tenkol.design.com.imbrecords.NetworkChangeReceiver: java.lang.ClassNotFoundException: tenkol.design.com.imbrecords.NetworkChangeReceiver 
     at android.app.ActivityThread.handleReceiver(ActivityThread.java:2541) 
     at android.app.ActivityThread.access$1500(ActivityThread.java:151) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1421) 
     at android.os.Handler.dispatchMessage(Handler.java:99) 
     at android.os.Looper.loop(Looper.java:155) 
     at android.app.ActivityThread.main(ActivityThread.java:5520) 
     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:1029) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:796) 
     at dalvik.system.NativeStart.main(Native Method) 
Caused by: java.lang.ClassNotFoundException: tenkol.design.com.imbrecords.NetworkChangeReceiver 
     at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:61) 
     at java.lang.ClassLoader.loadClass(ClassLoader.java:501) 
     at java.lang.ClassLoader.loadClass(ClassLoader.java:461) 
     at android.app.ActivityThread.handleReceiver(ActivityThread.java:2536) 
            at android.app.ActivityThread.access$1500(ActivityThread.java:151) 
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1421) 
            at android.os.Handler.dispatchMessage(Handler.java:99) 
            at android.os.Looper.loop(Looper.java:155) 
            at android.app.ActivityThread.main(ActivityThread.java:5520) 
            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:1029) 
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:796) 
            at dalvik.system.NativeStart.main(Native Method) 

Цель приемника прост - сделать тост этого нужно просто, когда подключение к Интернету не было.

Manifest:

<receiver 
     android:name=".NetworkChangeReceiver" 
     android:label="NetworkChangeReceiver" > 
     <intent-filter> 
      <action android:name="android.net.conn.CONNECTIVITY_CHANGE" /> 
     </intent-filter> 
    </receiver>  

и сам приемник:

public class NetworkChangeReceiver extends BroadcastReceiver { 

@Override 
public void onReceive(final Context context, final Intent intent) { 

    String status = InternetConnection.getConnectivityStatusString(context); 

    if (status != null) { 
     if (status.equals("Not connected to Internet")) { 
      Toast.makeText(context, context.getString(R.string.lost_internet_connection), Toast.LENGTH_SHORT).show(); 
     } 
    } 
} 

Это методы, которые он использует:

public static int getConnectivityStatus(Context context) { 
    ConnectivityManager cm = (ConnectivityManager) context 
      .getSystemService(Context.CONNECTIVITY_SERVICE); 

    NetworkInfo activeNetwork = cm.getActiveNetworkInfo(); 
    if (null != activeNetwork) { 
     if (activeNetwork.getType() == ConnectivityManager.TYPE_WIFI) 
      return TYPE_WIFI; 

     if (activeNetwork.getType() == ConnectivityManager.TYPE_MOBILE) 
      return TYPE_MOBILE; 
    } 
    return TYPE_NOT_CONNECTED; 
} 

public static String getConnectivityStatusString(Context context) { 
    int conn = InternetConnection.getConnectivityStatus(context); 
    String status = null; 
    if (conn == InternetConnection.TYPE_NOT_CONNECTED) { 
     status = "Not connected to Internet"; 
    } 
    return status; 
} 

Любые идеи, что вызывает сбои? Благодарю.

ответ

2

ClassNotFoundException является показателем того, что APK вашего приложения не построено правильно. Похоже, что ошибка сборки dex; ключ заключается в том, что исключение выбрано методом BaseDexClassLoader.findClass().

Я наблюдал эту ошибку в следующих ситуациях ранее:

1. я использовал физическое устройство (т.е. не эмулятор), который KITKAT АРТ включен. Когда я запустил приложение на другом устройстве Kitkat со временем выполнения Dalvik, ошибка, похоже, исчезла.

2. Эта проблема возникла из-за ошибки сборки .dex, которая произошла, когда я переместил SVN в другое место. Я полностью удалил старый проект и создал новый репозиторий из исходного проекта на моем компьютере, и после полного восстановления проекта ошибка снова не появилась.

3. Если вы используете Eclipse с Maven, и вы включили , попробуйте отключить его и построить проект. Если вы используете Android Studio, установите multiDexEnabled = false. Это известная причина этой ошибки.

В принципе, вам необходимо правильно перестроить проект, и ошибка исчезнет.

+0

Спасибо! Я сделаю это и понаблюдаю в течение некоторого времени. Если он решает проблему, я отмечаю ваш ответ – AnZ