2 votes

java.lang.InstantiationException

Je suis en train de créer une application pour envoyer un nombre X de textes à des personnes et après avoir réécrit mon code pour inclure les fils, il s'est cassé. De plus, la partie "Thread.sleep(3000) ;" du code va-t-elle geler l'interface utilisateur, ou le fait d'avoir tout mon code dans un thread va-t-il résoudre ce problème ? Dernière question : comment puis-je empêcher le script de s'arrêter lorsqu'il est en arrière-plan (pour continuer à envoyer) ?

public abstract class multisender2 extends Activity implements Runnable {
    @Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
    public void csend(View view) {
     EditText number = (EditText)findViewById(R.id.pnumber);
     EditText message = (EditText)findViewById(R.id.pmessage);
     EditText hmany = (EditText)findViewById(R.id.hmany);
     String _hmany = hmany.getText().toString();
     final String _number = number.getText().toString();
     final String _message = message.getText().toString();
     final int xtime = Integer.parseInt(_hmany);
     final int count = 1;
    Thread background = new Thread(new Runnable() { 

@Override
public void run() {
    try {
    if (count > xtime == false){
    SmsManager.getDefault().sendTextMessage(_number, null, _message, null, null);
        Thread.sleep(3000);
              }
    } catch (InterruptedException e) {
 }
 }

});       
    background.start();
}
}

Merci, et voici le LogCat

07-12 21:04:40.222 : E/AndroidRuntime(13948) : FATAL EXCEPTION : main 07-12 21:04:40.222 : E/AndroidRuntime(13948) : java.lang.RuntimeException : Impossible d'instancier l'activité ComponentInfo{com.dillonregi.multisender/com.dillonregi.multisender.multisender2} : java.lang.InstantiationException : com.dillonregi.multisender.multisender2 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1580) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1674) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.ActivityThread.access$1500(ActivityThread.java:117) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.ActivityThread$H.handleMessage(ActivityThread.java:942) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.os.Handler.dispatchMessage(Handler.java:99) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.os.Looper.loop(Looper.java:130) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.ActivityThread.main(ActivityThread.java:3701) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at java.lang.reflect.Method.invokeNative(Native Method) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at java.lang.reflect.Method.invoke(Method.java:507) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at com.Android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:895) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at com.Android.internal.os.ZygoteInit.main(ZygoteInit.java:653) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at dalvik.system.NativeStart.main(Méthode native) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : Causé par : java.lang.InstantiationException : com.dillonregi.multisender.multisender2 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at java.lang.Class.newInstanceImpl(Méthode native) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at java.lang.Class.newInstance(Class.java:1409) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.Instrumentation.newActivity(Instrumentation.java:1021) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1572) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : ... 11 plus 07-12 21:04:40.222 : E/AndroidRuntime(13948) : [Blue Error Handler] Créer un fichier de rapport de débogage pour main 07-12 21:04:40.222 : E/AndroidRuntime(13948) : java.lang.RuntimeException : Unable to instantiate activity ComponentInfo{com.dillonregi.multisender/com.dillonregi.multisender.multisender2} : java.lang.InstantiationException : com.dillonregi.multisender.multisender2 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1580) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1674) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.ActivityThread.access$1500(ActivityThread.java:117) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.ActivityThread$H.handleMessage(ActivityThread.java:942) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.os.Handler.dispatchMessage(Handler.java:99) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.os.Looper.loop(Looper.java:130) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.ActivityThread.main(ActivityThread.java:3701) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at java.lang.reflect.Method.invokeNative(Native Method) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at java.lang.reflect.Method.invoke(Method.java:507) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at com.Android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:895) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at com.Android.internal.os.ZygoteInit.main(ZygoteInit.java:653) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at dalvik.system.NativeStart.main(Méthode native) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : Causé par : java.lang.InstantiationException : com.dillonregi.multisender.multisender2 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at java.lang.Class.newInstanceImpl(Native Method) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at java.lang.Class.newInstance(Class.java:1409) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.Instrumentation.newActivity(Instrumentation.java:1021) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : at Android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1572) 07-12 21:04:40.222 : E/AndroidRuntime(13948) : ... 11 plus

0voto

AVD Points 57984

Ne pas bloquer le principal fil. Essayez d'utiliser AsyncTask . Pour plus d'informations, lisez - Processus et fils

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X