2013-05-15 142 views
0

我試圖讓一個應用程序從.txt文件讀取到一個hashmap中,然後在按鈕單擊時打印一個隨機hashmap條目。但我得到的錯誤,如「致命的例外:主」,我可以弄清楚是什麼問題。Android從txt讀取到hashmap

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的:

05-15 16:25:12.906:d/AndroidRuntime(4135):關閉VM 05-15 16:25:12.906:W/dalvikvm(4135):線程ID = 1:線程退出未捕獲異常(組= 0x40a71930) 05-15 16:25:12.927:E/AndroidRuntime(4135):致命例外:主 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):at 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) E/AndroidRuntime(4135):at android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1234) 05-15 16:25:12.927:E/AndroidRuntime(4135) :at android.os.Handler.dispatchMessage(Handler.java:99) 05-15 16:25:12.927:E/AndroidRuntime(4135):at android.os.Looper.loop(Looper.java:137) 05 -15 16:25:12.927:E/AndroidRuntime(4135):at android.app.ActivityThread.main(ActivityThread.java:5041) 05-15 16:25:12.927:E/AndroidRuntime(4135):在java.lang.reflect.Method.invokeNative(Native Method) 05-15 16:25:12.927:E/AndroidRuntime(4135):at java方法.invoke(Method.java:511) 05-15 16:25:12.927:E/AndroidRuntime(4135):at com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java :793) 05-15 16:25:12.927:E/AndroidRuntime(4135):at 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):at com.MorHam.qoutes.register。(MainActivity.java:120) 05-15 16:25:12.927:E/AndroidRuntime 4135):at com.MorHam.qoutes.MainActivity.onCreate(MainActivity.java:19) 05-15 16:25:12.927:E/AndroidRuntime(4135):at android.app.Activity.performCreate(Activity.java: 5104) 05-15 16:25:12.927:E/AndroidRuntime(4135):at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080) 05-15 16:25:12.927:E/AndroidRuntime(4135) :at 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/2972​​K,暫停15ms + 36ms,總計166ms

+3

我都沒有。發佈你的logcat – Blackbelt

回答

0

您可以在您添加了logcat中看到:java.lang.ArrayIndexOutOfBoundsException:

所致長度= 1;索引= 1月五日日至15日16:25:12.927:E/AndroidRuntime(4135):在com.MorHam.qoutes.register(MainActivity.java:120)

這意味着你的陣列具有元素,並且您正嘗試訪問第二個元素。

String sitat = split[1];