我正在使用此代码将详细信息插入到TwoDimensional Array中。但是,从数组中检索数据时,第一个元素值将更改为null。
Cursor consultancy = db.getConsultancy(this);
if(consultancy!=null)
{
consultancy.moveToFirst();
consultancy.moveToNext();
consultancynames = new String[(int) db.getConsultancyCount()-1];
for(int i=0;i<db.getConsultancyCount()-1;i++)
{
consultancynames[i] = consultancy.getString(2);
int consultantid = Integer.parseInt(consultancy.getString(consultancy.getColumnIndex(TimeAndExpensesLocalDB.CT_CONSULTANCYID)));
Cursor project_namecur = db.getProjectCode(this, consultantid);
if(project_namecur!=null)
{
project_namecur.moveToFirst();
projectname = new String[(int) db.getConsultancyCount()][project_namecur.getCount()];
for(int j=0;j<project_namecur.getCount();j++)
{
projectname[i][j] = project_namecur.getString(3);
project_namecur.moveToNext();
}
}
consultancy.moveToNext();
}
}
//... Print array
for (int i =0; i < consultancynames.length; i++) {
for (int j = 0; j < projectname.length; j++) {
System.out.print(" " + projectname[i][j]);
}
System.out.println("");
}
输出
05-25 12:58:22.700: I/System.out(2373): null null null
05-25 12:58:22.700: I/System.out(2373): Other-1 Other-2 Other-3
我不确定发生了什么。
感谢您的帮助..
答案 0 :(得分:4)
您正在循环的每次迭代中创建一个新数组:
projectname = new String[(int) db.getConsultancyCount()][project_namecur.getCount()];
因此,在第一次迭代中,您将创建一个数组并填充数组的第一个“行”。在第二次迭代中,您将创建一个新数组(默认为具有null元素)并填入第二个行。
我怀疑你需要在循环之前分配“外部”数组,然后根据该顾问的项目名称分配“内部”数组:
// Note: more idiomatic names would be consultancyNames and
// projectNames. It's also unclear why you're subtracting one from the count...
consultancynames = new String[(int) db.getConsultancyCount() - 1];
projectnames = new String[consultancynames.length][];
for (int i = 0;i< consultancenames.length; i++) {
...
projectnames[i] = new String[project_namecur.getCount())];
...
}
然后您还需要更改显示代码,例如到
for (int i =0; i < projectname.length; i++) {
for (int j = 0; j < projectname[i].length; j++) {
System.out.print(" " + projectname[i][j]);
}
System.out.println("");
}
答案 1 :(得分:0)
请注意,您无法执行以下操作:
projectname = new String[(int) db.getConsultancyCount()][project_namecur.getCount()];
for(int j=0;j<project_namecur.getCount();j++)
{
projectname[i][j] = project_namecur.getString(3);
project_namecur.moveToNext();
}
原因如下:
在第一行projectname
之后将是一个数组数组。
由于数组是对象引用,因此您有一个对象引用数组。
由于对象引用的默认值为null
,因此您将拥有一个null
元素数组。
这意味着你无法做到
projectname[i][j] = project_namecur.getString(3);
因为它对应
String[] row = projectname[i];
// row == null !
row[j] = project_namecur.getString(3);