-1

我有一个名为Tab1的片段,我从中调用名为sendStatusTab1的方法并将结果存储在String数组中。 sendStatusTab1进一步调用MyDBHandler中的retrieveStatus方法,该方法也返回一个数组。Android中使用字符串数组的空指针异常

我收到了NullPointerException,正如您在代码中看到的,并提供了进一步的错误。

我该如何纠正它?

代码为Tab1片段:在MyDBHandler

public String[] sendStatusTab1(int table) { 
    arraystatus = dbHandler.retrieveStatus(arraystatus, table); 
    return arraystatus; 
} 

代码的方法:在MainActivity2

package com.example.mrbrminocha.login; 

import android.os.Bundle; 
import android.support.annotation.Nullable; 
import android.support.v4.app.Fragment; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 

import android.widget.ImageButton; 
import android.widget.TextView; 

import java.util.zip.Inflater; 

public class Tab1 extends Fragment { 
    ImageButton IB; 
    TextView parking_left; 
    String buttonID; 
    String arrayStatus[] = new String[86]; 
    int booked_counter=0; 

    @Override 
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { 
     View v = inflater.inflate(R.layout.tab_1,container,false); 

     arrayStatus = ((MainActivity2)this.getActivity()).sendStatusTab1(1); 

     for (int i = 0; i < 86; i++) { 
      buttonID = "button" + (i + 1); 
      int resID = getResources().getIdentifier(buttonID, "id", ((MainActivity2) this.getActivity()).getPackageName()); 
      IB = (ImageButton) v.findViewById(resID); 
      if (arrayStatus[i].equals("Booked")) { 
       booked_counter++; 
       IB.setImageResource(R.drawable.grey1); 
       IB.setClickable(false); 
      } 
     } 

     parking_left = (TextView) v.findViewById(R.id.counter); 
     parking_left.setText("Parking Left" + (86-booked_counter) + "/86"); 
     booked_counter = 0; 
     return v; 
    } 
} 

代码方法示值误差

public String[] retrieveStatus(String array[],int table) { 

    String table_name = ""; 
    switch (table) { 
     case 1: table_name = TABLE1; 
       break; 
    } 
    int index = 0; 
    String dbString = ""; 
    SQLiteDatabase db = getWritableDatabase(); 
    String query = "SELECT * FROM" + TABLE1 + "WHERE 1"; 

    Cursor c = db.rawQuery(query, null); 
    c.moveToFirst(); 

    while (!c.isAfterLast()) { 
     if (c.getString(c.getColumnIndex("buttonstatus")) != null) { 
      array[index++] = c.getString(c.getColumnIndex("buttonstatus")); 
     } 
     c.moveToNext(); 
    } 
    db.close(); 
    return array; 
} 

为什么我收到NullPointerException ,我该如何解决这个问题?

java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String[] com.example.mrbrminocha.login.MyDBHandler.retrieveStatus(java.lang.String[], int)' on a null object reference 
    at com.example.mrbrminocha.login.MainActivity2.sendStatusTab1(MainActivity2.java:16 1) 
    at com.example.mrbrminocha.login.Tab1.onCreateView(Tab1.java:33) 

回答

1

你的sql查询是错误的。你忘记了fromwhere之间的空格。 这是正确的查询:

String query = "SELECT * FROM " + TABLE1 + " WHERE 1"; 
+0

感谢乌拉圭回合的答复,但没有例外,我的应用程序正在运行之前,我增加了一些新功能,其中包括我上面指定的代码。这个查询没有问题。如果你有其他建议,回复? –