1

次のメッセージでクラッシュしました。

04-17 11:18:19.855: W/dalvikvm(368): threadid=1: thread exiting with uncaught exception (group=0x4001d800)
04-17 11:18:19.925: E/AndroidRuntime(368): FATAL EXCEPTION: main
04-17 11:18:19.925: E/AndroidRuntime(368): java.lang.IllegalStateException: Could not execute method of the activity
04-17 11:18:19.925: E/AndroidRuntime(368):  at android.view.View$1.onClick(View.java:2072)
04-17 11:18:19.925: E/AndroidRuntime(368):  at android.view.View.performClick(View.java:2408)
04-17 11:18:19.925: E/AndroidRuntime(368):  at android.view.View$PerformClick.run(View.java:8816)
04-17 11:18:19.925: E/AndroidRuntime(368):  at android.os.Handler.handleCallback(Handler.java:587)
04-17 11:18:19.925: E/AndroidRuntime(368):  at android.os.Handler.dispatchMessage(Handler.java:92)
04-17 11:18:19.925: E/AndroidRuntime(368):  at android.os.Looper.loop(Looper.java:123)
04-17 11:18:19.925: E/AndroidRuntime(368):  at android.app.ActivityThread.main(ActivityThread.java:4627)
04-17 11:18:19.925: E/AndroidRuntime(368):  at java.lang.reflect.Method.invokeNative(Native Method)
04-17 11:18:19.925: E/AndroidRuntime(368):  at java.lang.reflect.Method.invoke(Method.java:521)
04-17 11:18:19.925: E/AndroidRuntime(368):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
04-17 11:18:19.925: E/AndroidRuntime(368):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
04-17 11:18:19.925: E/AndroidRuntime(368):  at dalvik.system.NativeStart.main(Native Method)
04-17 11:18:19.925: E/AndroidRuntime(368): Caused by: java.lang.reflect.InvocationTargetException
04-17 11:18:19.925: E/AndroidRuntime(368):  at com.UturpatShuPepper.LogCat.TheLogCatActivity.onGo(TheLogCatActivity.java:41)
04-17 11:18:19.925: E/AndroidRuntime(368):  at java.lang.reflect.Method.invokeNative(Native Method)
04-17 11:18:19.925: E/AndroidRuntime(368):  at java.lang.reflect.Method.invoke(Method.java:521)
04-17 11:18:19.925: E/AndroidRuntime(368):  at android.view.View$1.onClick(View.java:2067)
04-17 11:18:19.925: E/AndroidRuntime(368):  ... 11 more
04-17 11:18:19.925: E/AndroidRuntime(368): Caused by: java.lang.ClassCastException: android.app.Application
04-17 11:18:19.925: E/AndroidRuntime(368):  ... 15 more

デバッガーを使用すると、次のコードのマークされた行でクラッシュが発生することがわかります。

// Go button pressed
public void onGo(View v) {
    final EditText et = (EditText) findViewById(R.id.filters);
    String filter = "food\\s+[ABC]";
    if(!ValidateText(et, "^\\s*(" + filter + "(\\s+)" + filter + ")?$", "Bad filters")) {
        return;
    }
--->GlobalApp app = (GlobalApp) getApplication(); <--- CRASHES HERE
    for(int i = 0; i &lt; 100; i++) {
       app.addMessage("message number " + i);
    }

ログによると、ClassCastException が原因です。

GlobalApp クラスを次のように定義しました。

public class GlobalApp extends Application {

private final ArrayList<String> messages = new ArrayList<String>();

public ArrayList<String> getMessages(){
    return messages;
}

public void addMessage(String msg){
    messages.add(msg);
}
}

なぜキャスティングが間違っているのですか?それを行う正しい方法は何ですか?

4

2 に答える 2

2

マニフェストでこれを変更します

<application android:icon="@drawable/icon" android:label="@string/app_name">

これで

<application android:icon="@drawable/icon" android:label="@string/app_name" android:name=".GlobalApp">

OS の android:name を指定していないため、デフォルトの Application クラスを探します。Application サブクラスを指すには、android:name 属性を使用する必要があります。

于 2012-04-17T09:06:56.223 に答える
0

マニフェストのアクティビティ行を次のように変更する必要があります

<activity android:name="GlobalApp" ...

于 2012-04-17T09:08:04.200 に答える