次のように作成された ButtonList というボタンの配列があります。
LinearLayout player=(LinearLayout)findViewById(R.id.playerlayout);
PlayerFirst=(Button)player.getChildAt(0);
for(int i=0;i<player.getChildCount();i++)
{
ButtonList.add((Button)player.getChildAt(i));
}
これらのボタンの値を順次インクリメントする必要があります (各変更の間に遅延があります)。次のコードがあります。
for( k=0;k<ButtonList.size();k++)
{
Handler handler = new Handler();
handler.postDelayed(new Runnable() {
public void run() {
ButtonList.get(getK()).setText(getK()+1+"");
}
}, 1000);
}
ここで getK() は、無名関数内の k にアクセスするための k のアクセサーです。
public int k;
public int getK()
{
return k;
}
アプリケーションがクラッシュします。私は何を間違っていますか?
LogCat エラー:
01-03 05:21:04.396: I/Process(1469): Sending signal. PID: 1469 SIG: 9
01-03 05:21:06.276: E/Trace(1535): error opening trace file: No such file or directory (2)
01-03 05:21:08.826: W/dalvikvm(1535): threadid=1: thread exiting with uncaught exception (group=0x2bd39930)
01-03 05:21:08.846: E/AndroidRuntime(1535): FATAL EXCEPTION: main
01-03 05:21:08.846: E/AndroidRuntime(1535): java.lang.IndexOutOfBoundsException: Invalid index 12, size is 12
01-03 05:21:08.846: E/AndroidRuntime(1535): at java.util.ArrayList.throwIndexOutOfBoundsException(ArrayList.java:251)
01-03 05:21:08.846: E/AndroidRuntime(1535): at java.util.ArrayList.get(ArrayList.java:304)
01-03 05:21:08.846: E/AndroidRuntime(1535): at com.example.awari.MainActivity$1.run(MainActivity.java:129)
01-03 05:21:08.846: E/AndroidRuntime(1535): at android.os.Handler.handleCallback(Handler.java:725)
01-03 05:21:08.846: E/AndroidRuntime(1535): at android.os.Handler.dispatchMessage(Handler.java:92)
01-03 05:21:08.846: E/AndroidRuntime(1535): at android.os.Looper.loop(Looper.java:137)
01-03 05:21:08.846: E/AndroidRuntime(1535): at android.app.ActivityThread.main(ActivityThread.java:5039)
01-03 05:21:08.846: E/AndroidRuntime(1535): at java.lang.reflect.Method.invokeNative(Native Method)
01-03 05:21:08.846: E/AndroidRuntime(1535): at java.lang.reflect.Method.invoke(Method.java:511)
01-03 05:21:08.846: E/AndroidRuntime(1535): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
01-03 05:21:08.846: E/AndroidRuntime(1535): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
01-03 05:21:08.846: E/AndroidRuntime(1535): at dalvik.system.NativeStart.main(Native Method)