我的应用程序一直在崩溃,似乎无法找到任何错误

时间:2014-06-07 17:13:07

标签: java android eclipse

当我启动我的应用程序时它工作正常但是只要我按下按钮将我带到MakeRap.activity它就会崩溃。我检查了MakeRap的活动,似乎没有错误。

以下是log cat所说的内容:

 06-07 11:57:09.173: I/Adreno200-EGLSUB(14785): <ConfigWindowMatch:2087>: Format      RGBA_8888.
 06-07 11:57:09.203: D/memalloc(14785): ion: Mapped buffer base:0x52531000 size:2088960    offset:0 fd:60
 06-07 11:57:09.203: D/OpenGLRenderer(14785): Enabling debug mode 0
 06-07 11:57:09.503: D/memalloc(14785): ion: Mapped buffer base:0x52ea4000 size:2088960 offset:0 fd:64
 06-07 11:57:10.955: D/AndroidRuntime(14785): Shutting down VM
 06-07 11:57:10.955: W/dalvikvm(14785): threadid=1: thread exiting with uncaught exception (group=0x40aaea08)
 06-07 11:57:10.975: E/AndroidRuntime(14785): FATAL EXCEPTION: main
 06-07 11:57:10.975: E/AndroidRuntime(14785): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.soloinc.meip/com.soloinc.meip.MakeRapActivity}: java.lang.ArrayIndexOutOfBoundsException: length=1; index=1
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2225)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2260)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at android.app.ActivityThread.access$600(ActivityThread.java:139)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1277)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at android.os.Handler.dispatchMessage(Handler.java:99)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at android.os.Looper.loop(Looper.java:156)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at android.app.ActivityThread.main(ActivityThread.java:5045)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at java.lang.reflect.Method.invokeNative(Native Method)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at java.lang.reflect.Method.invoke(Method.java:511)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at dalvik.system.NativeStart.main(Native Method)
 06-07 11:57:10.975: E/AndroidRuntime(14785): Caused by: java.lang.ArrayIndexOutOfBoundsException: length=1; index=1
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at com.soloinc.meip.MakeRapActivity.onCreate(MakeRapActivity.java:59)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at android.app.Activity.performCreate(Activity.java:4543)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1071)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2181)
 06-07 11:57:10.975: E/AndroidRuntime(14785):   ... 11 more

Heres MakeRapActivity

import java.io.BufferedReader;
import java.io.Console;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List;

import android.media.MediaPlayer;
import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.content.res.AssetFileDescriptor;
import android.content.res.AssetManager;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.Toast;

public class MakeRapActivity extends Activity 
{
    ListView instruments_list;
    protected List<String> instrument_title_list;
    protected List<String> instrument_audio_file_list;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_make_rap);
         // Get ListView object from xml
        instruments_list = (ListView) findViewById(R.id.instruments_list);

        //Getting list of all files From name_mapping.txt
        instrument_title_list = new ArrayList<String>();
        instrument_audio_file_list = new ArrayList<String>();

        InputStream inputStream = getResources().openRawResource(R.raw.name_mapping);
        BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream));
        String line = null;
        try 
        {
            line = reader.readLine();
        }
        catch (IOException e) 
        {
            e.printStackTrace();
        }
        while (line != null) 
        {
            String[] temp = line.split(",");
            instrument_audio_file_list.add(temp[0]);
            instrument_title_list.add(temp[1]);

            try 
            {
                line = reader.readLine();
            }
            catch (IOException e) 
            {
                e.printStackTrace();
            }
        }
        try {
            reader.close();
            inputStream.close();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        // Define a new Adapter
        // First parameter - Context
        // Second parameter - Layout for the row
        // Third parameter - ID of the TextView to which the data is written
        // Forth - the Array of data
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
          android.R.layout.simple_list_item_1, android.R.id.text1, instrument_title_list);


        // Assign adapter to ListView
        instruments_list.setAdapter(adapter); 
        // ListView Item Click Listener
        instruments_list.setOnItemClickListener(new OnItemClickListener() 
        {

            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position,long id) 
            {           
                   // ListView Clicked item value
                   String  instrument_title_clicked    = (String) instruments_list.getItemAtPosition(position);
                   Intent intent = new Intent(MakeRapActivity.this,RecordRap.class);
                   intent.putExtra("instrument_title",instrument_title_clicked);
                   intent.putExtra("instrument_file_name", get_Instrument_file_name(instrument_title_clicked));
                   startActivity(intent);
            }

         }); 
    }

    @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;
    }

    public String get_Instrument_file_name(String instrument_title)
    {
        int position = 0;
        for(int i = 0; i < instrument_title_list.size(); i++)
        {
            if(instrument_title_list.get(i).equals(instrument_title))
            {
                position = i;
            }
        }

        return instrument_audio_file_list.get(position);
    }

}

以下是按钮的活动:

import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;

public class MainActivity extends Activity implements OnClickListener {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    @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;
    }

    @Override
    public void onClick(View view) 
    {

        switch(view.getId())
        {

            case R.id.button1:
                //creating an intent to goto activity to add a new record
                Intent it=new Intent(MainActivity.this,MakeRapActivity.class);
                //starting new activity
                startActivity(it);
            break;

        }
    }
}

1 个答案:

答案 0 :(得分:1)

您的问题是以下几行

String[] temp = line.split(",");
instrument_audio_file_list.add(temp[0]);
instrument_title_list.add(temp[1]);

发生的崩溃是一个索引超出范围的异常,并指示该数组的大小为1,并且您正在尝试访问数组中仅包含1个元素的第二个元素。当您使用split命令时,它将始终具有第一个条目,但不能保证有更多。问题是在某些时候你遇到了一个不包含“,”的行变量,你得到一个越界错误。

改为这样的

String[] temp = line.split(",");
instrument_audio_file_list.add(temp[0]);

if (temp.length > 1) {
    instrument_title_list.add(temp[1]);
} else {
    instrument_title_list.add("");
}

这将确保您没有崩溃,并且如果没有逗号则会插入空字符串。

这也可以通过修复输入文件来解决,以确保每行至少有一个逗号。取决于您正在寻找的结果。