当我通过ListView {in content_main.xml}(如联系人视图)创建显示列表的代码时出现错误

时间:2017-09-08 13:36:03

标签: java android sqlite listview compiler-errors

我正在创建一个代码,通过ListView {在content_main.xml}创建一个显示列表,如联系人视图。  我在(SQLite Expert Professional)中构建了一个数据库,其中包含一个表(名称:" contact"),其中包含一些名称,系列和数字,以及ID,NAME,fAMILY和PHONE NUMBER列。 ID是唯一的,自动增量和主键...其他是文本除CHAR之外的数字。  然后我将它们调用到我的ListView,如下所示。(在它之前我做了一个row_list活动来制作我的listview,自定义)但是有一个错误,我无法找到它。 {我可以在源数据文件中找到包含该表的database.db文件,这意味着我的错误不是创建数据库。} PLZ帮助我。我想学习android(尽可能快)得到一份工作,我需要它..

Errors.Android Monitor.Logcat

09-08 05:27:32.005 5692-5692/? W/dalvikvm: threadid=1: thread exiting with uncaught exception (group=0x94c4fb20)
09-08 05:27:32.005 5692-5692/? E/AndroidRuntime: FATAL EXCEPTION: main
Process: mizco.phonebook, PID: 5692
java.lang.RuntimeException: Unable to start activity ComponentInfo{mizco.phonebook/mizco.phonebook.Main}: android.database
.CursorIndexOutOfBoundsException: Index 5 requested, with a size of 5
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2193)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2243)
at android.app.ActivityThread.access$800(ActivityThread.java:135)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5019)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
Caused by: android.database.CursorIndexOutOfBoundsException: Index 5 requested, with a size of 5
at android.database.AbstractCursor.checkPosition(AbstractCursor.java:426)
at android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:136)
at android.database.AbstractWindowedCursor.getString(AbstractWindowedCursor.java:50)
at mizco.phonebook.database.getfulllist(database.java:97)
at mizco.phonebook.Main.onCreate(Main.java:36)
at android.app.Activity.performCreate(Activity.java:5231)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1104)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2157)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2243)
at android.app.ActivityThread.access$800(ActivityThread.java:135)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 
at android.os.Handler.dispatchMessage(Handler.java:102) 
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5019)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)

Main.java

package mizco.phonebook;

import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.design.widget.FloatingActionButton;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;

public class Main extends AppCompatActivity {
    private database db;
    private String [][] res ;

    private ListView list;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);

    list = (ListView) findViewById(R.id.main_list);

    db = new database(this);
    db.startusing();

    db.open();
    res = db.getfulllist();
    db.close();


    list.setAdapter(new AA());


    FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
    fab.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
        }
    });

}


class AA extends ArrayAdapter<String>{

    public AA() {

        super(Main.this, R.layout.row_list, res[0]);
    }
    @NonNull
    @Override
    public View getView(final int position, View convertView, ViewGroup parent) {

        LayoutInflater in = getLayoutInflater();
        View row = in.inflate(R.layout.row_list,parent,false);

        TextView name = (TextView) row.findViewById(R.id.row_name);
        TextView number = (TextView) row.findViewById(R.id.row_number);

        name.setText(res[0][position]+" "+res[1][position]);
        number.setText(res[2][position]);
        return row;
    }
}

}

类:database.java

package mizco.phonebook;

import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;

/**
 * Created by Mahdi on 9/2/2017.
 */

public class database extends SQLiteOpenHelper {

public static String dbname= "database";
public static String dbpath="";
private Context mctxt;

private SQLiteDatabase mydb;


public database(Context context) {
    super(context, dbname, null, 1);
    mctxt = context;
}

@Override
public void onCreate(SQLiteDatabase db) {

}

@Override
public void onUpgrade(SQLiteDatabase db, int i, int i1) {

}

private boolean existdatabase(){
    File m312 = new File(dbpath+dbname);

        return m312.exists();
}


private void copydatabase(){
    try {
        InputStream IS = mctxt.getAssets().open(dbname);
        OutputStream OS = new FileOutputStream(dbpath+dbname);


        byte[] buffer = new byte[1024];
        int length;

        while ((length = IS.read(buffer))>0){
         OS.write(buffer,0,length);
        }
        OS.flush();
        OS.close();
        IS.close();

    } catch (Exception e) {
    }
}

public void open(){
    mydb = SQLiteDatabase.openDatabase(dbpath+dbname, null, SQLiteDatabase.OPEN_READWRITE);
}

public void close(){
    mydb.close();
}




public void startusing () {
    dbpath = mctxt.getFilesDir().getParent() + "/databases/";
    if (!existdatabase()) {
        this.getWritableDatabase();
        copydatabase();
    }
}

public String[][] getfulllist(){


    Cursor cu = mydb.rawQuery("select * from Contact",null);

    String [][] r = new String[3][cu.getCount()];
    for (int i= 0;i<=cu.getCount();i++){
        cu.moveToPosition(i);

        r[0][i]=cu.getString(1);
        r[1][i]=cu.getString(2);
        r[2][i]=cu.getString(3);
    }

    return r;
}

}

1 个答案:

答案 0 :(得分:0)

你走开光标的尽头。您的代码应该是

for (int i= 0;i < cu.getCount();i++){
        cu.moveToPosition(i);

        r[0][i]=cu.getString(1);
        r[1][i]=cu.getString(2);
        r[2][i]=cu.getString(3);
    }
return r;