Android Чтение из txt в hashmap

Я пытаюсь создать приложение, которое считывает файл .txt в хэш-карту, а затем печатает случайную запись хэш-карты при нажатии кнопки. Но я получаю сообщение об ошибке типа «FATAL EXCEPTION: main», я могу понять, в чем проблема.

public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);


    register r = new register();
    final HashMap<String, quote> quotes = r.getMap();


    final Random rand = new Random();

    final Button newQuote = (Button) findViewById(R.id.button1);
    final Button clear = (Button) findViewById(R.id.button2);
    final TextView text = (TextView) findViewById(R.id.Text1);
    newQuote.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            int i = rand.nextInt(4);
            String kode = ""+i;
            // TODO Auto-generated method stub
            text.setText(quotes.get(kode).sitat);

        }
    });

    clear.setOnClickListener(new View.OnClickListener() {


        @Override
        public void onClick(View v) {
            text.setText("Sitat");
            // TODO Auto-generated method stub

        }
    });


}  

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}
}

class quote{
String kode;
String sitat;
String forfatter;

quote(String kode, String sitat, String forfatter){
    this.kode = kode;
    this.sitat = sitat;
    this.forfatter = forfatter;

}

public String hentSitat(){
    return sitat;

}
public String hentForfatter(){
    return forfatter;
}

}

class register{
HashMap<String, quote> quotes = new HashMap<String, quote>();

register(){
    Scanner sc = new Scanner("sitater");

    while(sc.hasNext()){
        String linje = sc.nextLine();
        String[] split = linje.split("\t");
        String kode = split[0];
        String sitat = split[1];
        String forfatter = split[2];
        quote q = new quote(kode, sitat, forfatter);
        quotes.put(kode, q);
    }

}
HashMap<String, quote> getMap(){
    return quotes;
}
}

Логкат:

Вы можете увидеть в LogCat, который вы добавили:


person user2139796    schedule 15.05.2013    source источник
comment
05-15 16:25:12.906: D/AndroidRuntime(4135): завершение работы виртуальной машины 05-15 16:25:12.906: W/dalvikvm(4135): threadid=1: поток завершается с необработанным исключением (группа=0x40a71930) 05 -15 16:25:12.927: E/AndroidRuntime(4135): НЕУСТОЙЧИВОЕ ИСКЛЮЧЕНИЕ: main 05-15 16:25:12.927: E/AndroidRuntime(4135): java.lang.RuntimeException: невозможно запустить активность ComponentInfo{com.MorHam .qoutes/com.MorHam.qoutes.MainActivity}: java.lang.ArrayIndexOutOfBoundsException: length=1; index=1 05-15 16:25:12.927: E/AndroidRuntime(4135): в android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180) 05-15 16:25:12.927: E/AndroidRuntime(4135): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230) 05-15 16:25:12.927: E/AndroidRuntime(4135): at android.app.ActivityThread.access$600(ActivityThread.java:141) 05-15 16:25:12.927: E/AndroidRuntime(4135): в android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234) 05-15 16:25:12.927: E/AndroidRuntime(4135): в android.os .Handler.dispatchMessage(Handler.java:99) 05-15 16:25:12.927: E/AndroidRuntime(4135): в android.os.Looper.loop(Looper.java:137) 05-15 16:25:12.927 : E/AndroidRuntime(4135): в android.app.ActivityThread.main(ActivityThread.java:5041) 05-15 16:25:12.927: E/AndroidRuntime(4135): в java.lang.reflect.Method.invokeNative( Родной метод) 05-15 16:25:12.927: E/AndroidRuntime(4135): в java.lang.reflect.Method.invoke(Method.java:511) 05-15 16:25:12.927: E/AndroidRuntime(4135): в com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 05-15 16:25:12.927: E/AndroidRuntime( 4135): в com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 05-15 16:25:12.927: E/AndroidRuntime(4135): в dalvik.system.NativeStart.main(собственный метод) 05-15 16:25:12.927: E/AndroidRuntime(4135): Причина: java.lang.ArrayIndexOutOfBoundsException: length=1; index=1 05-15 16:25:12.927: E/AndroidRuntime(4135): в com.MorHam.qoutes.register.(MainActivity.java:120) 05-15 16:25:12.927: E/AndroidRuntime(4135) : в com.MorHam.qoutes.MainActivity.onCreate(MainActivity.java:19) 05-15 16:25:12.927: E/AndroidRuntime(4135): в android.app.Activity.performCreate(Activity.java:5104) 05 -15 16:25:12.927: E/AndroidRuntime(4135): в android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080) 05-15 16:25:12.927: E/AndroidRuntime(4135): в android.app .ActivityThread.performLaunchActivity(ActivityThread.java:2144) 05–15 16:25:12. 927: E/AndroidRuntime(4135): ... еще 11 05-15 16:25:12.998: D/dalvikvm(4135): GC_CONCURRENT освобождено 151K, 10% свободно 2698K/2972K, пауза 15мс+36мс, всего 166мс   -  person Blackbelt    schedule 15.05.2013


Ответы (1)


Вызвано: java.lang.ArrayIndexOutOfBoundsException: length=1; index=1 05-15 16:25:12.927: E/AndroidRuntime(4135): в com.MorHam.qoutes.register.(MainActivity.java:120)

Это означает, что в вашем массиве есть элемент 1, и вы пытаетесь получить доступ ко второму элементу.

и я нет. Опубликуйте свой логкэт

String sitat = split[1];
person Uriel Frankel    schedule 15.05.2013