1

SMS (2 つのエミュレーターでのテスト) を受信したときにプログレスバーの進行状況を増やしたいのですが、エラーが発生しました - 予期せず、強制的に閉じます。

アクティビティ A のコードは次のとおりです。

progressBar = (ProgressBar)findViewById(R.id.progresslevel);
  new Thread(new Runnable() {
    public void run() {
      // TODO Auto-generated method stub
      while (progressStatus < 50000) {
        mHandler.post(new Runnable() {
          public void run() {
            // TODO Auto-generated method stub
            progressBar.setProgress(progressStatus);
          }
        });
      }
  }).start();

アクティビティ A の増加方法:

public static void increaseValue(Boolean isSMS) {
  if (isSMS == true) {
    progressStatus += 5000;
  } else {
    progressStatus += 7000;
  }
}

マイ アクティビティ SMSReceiver:

public class SMSReceive extends BroadcastReceiver {
  @Override
    public void onReceive(Context context, Intent intent) {
      // TODO Auto-generated method stub
      FloCareActivity.increaseValue(true);
    }
}

それを修正する方法?

ログ cat からのエラー:

    06-28 11:24:33.733: W/dalvikvm(915): threadid=3: thread exiting with uncaught exception (group=0x4001aa28)
06-28 11:24:33.733: E/AndroidRuntime(915): Uncaught handler: thread main exiting due to uncaught exception
06-28 11:24:33.763: E/AndroidRuntime(915): java.lang.RuntimeException: Unable to instantiate receiver nth.flocare.demo.SMSReceiver: java.lang.ClassNotFoundException: nth.flocare.demo.SMSReceiver in loader dalvik.system.PathClassLoader@43757c18
06-28 11:24:33.763: E/AndroidRuntime(915):  at android.app.ActivityThread.handleReceiver(ActivityThread.java:2520)
06-28 11:24:33.763: E/AndroidRuntime(915):  at android.app.ActivityThread.access$3000(ActivityThread.java:116)
06-28 11:24:33.763: E/AndroidRuntime(915):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1843)
06-28 11:24:33.763: E/AndroidRuntime(915):  at android.os.Handler.dispatchMessage(Handler.java:99)
06-28 11:24:33.763: E/AndroidRuntime(915):  at android.os.Looper.loop(Looper.java:123)
06-28 11:24:33.763: E/AndroidRuntime(915):  at android.app.ActivityThread.main(ActivityThread.java:4203)
06-28 11:24:33.763: E/AndroidRuntime(915):  at java.lang.reflect.Method.invokeNative(Native Method)
06-28 11:24:33.763: E/AndroidRuntime(915):  at java.lang.reflect.Method.invoke(Method.java:521)
06-28 11:24:33.763: E/AndroidRuntime(915):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:791)
06-28 11:24:33.763: E/AndroidRuntime(915):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:549)
06-28 11:24:33.763: E/AndroidRuntime(915):  at dalvik.system.NativeStart.main(Native Method)
06-28 11:24:33.763: E/AndroidRuntime(915): Caused by: java.lang.ClassNotFoundException: nth.flocare.demo.SMSReceiver in loader dalvik.system.PathClassLoader@43757c18
06-28 11:24:33.763: E/AndroidRuntime(915):  at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
06-28 11:24:33.763: E/AndroidRuntime(915):  at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
06-28 11:24:33.763: E/AndroidRuntime(915):  at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
06-28 11:24:33.763: E/AndroidRuntime(915):  at android.app.ActivityThread.handleReceiver(ActivityThread.java:2513)
06-28 11:24:33.763: E/AndroidRuntime(915):  ... 10 more
06-28 11:24:33.813: I/dalvikvm(915): threadid=7: reacting to signal 3
06-28 11:24:33.895: I/dalvikvm(915): Wrote stack trace to '/data/anr/traces.txt'
06-28 11:29:33.833: I/Process(915): Sending signal. PID: 915 SIG: 9
4

2 に答える 2

2

これは、マニフェストが Android に という名前のクラスがnth.flocare.demo.SMSReceiverあり、Android がそれを見つけられないことを伝えていることを意味します。

あなたがしたエラーは

コードのようにクラス名がSMSReceiveあり、Androidが見つけようとしているnth.flocare.demo.SMSReceiverので、クラスの名前を次のように変更しますSMSReceiver

于 2012-06-28T04:55:33.303 に答える
0

あなたのコードには、新しいs をできるだけ早くイベント ループにThread投稿する作成したループがあります。これが唯一の問題であるかどうかを確認するのに十分なコードまたはスタック トレースを投稿していませんが、修正する必要があるのは確かです。進行状況の値が変化した場合にのみメッセージを投稿します。確かに、別のスレッドでそれを行う必要はありません。非常に高速な操作です。追加のスレッドは、長い操作によって UI スレッドが遅延するのを防ぐためにのみ使用してください。RunnableHandler

于 2012-06-28T04:51:11.923 に答える