异常 - NullPointer在ListView中从服务器检索数据

时间:2013-05-22 09:28:41

标签: android android-listview

我已经在服务器上的表中存储了一些数据,现在我试图在ListView中显示该数据,但每次我得到 NULL POINTER EXCEPTION 时,请检查我的下面的代码

OrdersAdapter.java:

  public class OrdersAdapter extends BaseAdapter {
TextView tName,tId,tOid ;
private Activity activity;
private ArrayList<HashMap<String, String>> data;
private static LayoutInflater inflater=null;
String strName,strMemberID ;

public OrdersAdapter(Activity a, ArrayList<HashMap<String, String>> d) {
    activity = a;
    data=d;
    inflater = (LayoutInflater)activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
}

public int getCount() {
    return data.size();
}

public Object getItem(int position) {
    return position;
}

public long getItemId(int position) {
    return position;
}

public View getView(int position, View convertView, ViewGroup parent) {
    View vi=convertView;
    if(convertView==null)
        vi = inflater.inflate(R.layout.listrow_orders, null);

    tId = (TextView)vi.findViewById(R.id.txtTotalAmount);
    tName = (TextView)vi.findViewById(R.id.txtItemDetails);

    HashMap<String, String> item = new HashMap<String, String>();
    item = data.get(position);

    tId.setText(item.get(strName));
    tName.setText(item.get(strMemberID));


        String url = "http://172.16.0.4/res/order_fetch.php";
        Intent intent= activity.getIntent();
        String MemberID = intent.getStringExtra("MemberID");
        List<NameValuePair> params = new ArrayList<NameValuePair>();
        params.add(new BasicNameValuePair("sMemberID", MemberID));
        String resultServer  = getHttpPost(url,params);

        strMemberID = "";
        strName = "";


        JSONObject c;
        try {
        c = new JSONObject(resultServer);
        strMemberID = c.getString("TotalAmount");               
        strName = c.getString("ItemDetails");

        if(!strMemberID.equals(""))
        {                   
            tName.setText(strName);
            tId.setText(strMemberID);               
        }
        else
        {               
            tName.setText("-");
            tId.setText("-");
        }
        } catch (JSONException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
        }
        return vi;

                  }     

    public String getHttpPost(String url,List<NameValuePair> params) {
        StringBuilder str = new StringBuilder();
        HttpClient client = new DefaultHttpClient();
        HttpPost httpPost = new HttpPost(url);

    try {
        httpPost.setEntity(new UrlEncodedFormEntity(params));
        HttpResponse response = client.execute(httpPost);
        StatusLine statusLine = response.getStatusLine();
        int statusCode = statusLine.getStatusCode();
        if (statusCode == 200) { // Status OK
            HttpEntity entity = response.getEntity();
            InputStream content = entity.getContent();
            BufferedReader reader = new BufferedReader(new InputStreamReader(content));
            String line;
            while ((line = reader.readLine()) != null) {
                str.append(line);
            }
        } else {
            Log.e("Log", "Failed to download result..");
        }
    } catch (ClientProtocolException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }
    return str.toString();
}
   }

OrdersActivity.java:

   public class OrdersActivity extends Activity 
{ 
    public static final String LOG_TAG = "OrdersActivity";
    ArrayList<HashMap<String, String>> d;
    ListView mLstView1;
    @Override

    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_orders);

        mLstView1 = (ListView) findViewById(R.id.listView1);
        OrdersAdapter ordersAdapter = new OrdersAdapter(OrdersActivity.this,d);            
        mLstView1.setAdapter(ordersAdapter);


        // Permission StrictMode
        if (android.os.Build.VERSION.SDK_INT > 9) {
            StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
            StrictMode.setThreadPolicy(policy);
        }
    }
}

Logcat报告:

     05-22 14:50:29.373: E/AndroidRuntime(780): FATAL EXCEPTION: main
05-22 14:50:29.373: E/AndroidRuntime(780): java.lang.RuntimeException: Unable to start activity ComponentInfo{OrdersActivity}: java.lang.NullPointerException
05-22 14:50:29.373: E/AndroidRuntime(780):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
05-22 14:50:29.373: E/AndroidRuntime(780):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
05-22 14:50:29.373: E/AndroidRuntime(780):  at android.app.ActivityThread.access$600(ActivityThread.java:141)
05-22 14:50:29.373: E/AndroidRuntime(780):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
05-22 14:50:29.373: E/AndroidRuntime(780):  at android.os.Handler.dispatchMessage(Handler.java:99)
05-22 14:50:29.373: E/AndroidRuntime(780):  at android.os.Looper.loop(Looper.java:137)
05-22 14:50:29.373: E/AndroidRuntime(780):  at android.app.ActivityThread.main(ActivityThread.java:5041)
05-22 14:50:29.373: E/AndroidRuntime(780):  at java.lang.reflect.Method.invokeNative(Native Method)
05-22 14:50:29.373: E/AndroidRuntime(780):  at java.lang.reflect.Method.invoke(Method.java:511)
05-22 14:50:29.373: E/AndroidRuntime(780):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
05-22 14:50:29.373: E/AndroidRuntime(780):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
05-22 14:50:29.373: E/AndroidRuntime(780):  at dalvik.system.NativeStart.main(Native Method)
05-22 14:50:29.373: E/AndroidRuntime(780): Caused by: java.lang.NullPointerException
05-22 14:50:29.373: E/AndroidRuntime(780):  at OrdersAdapter.getCount(OrdersAdapter.java:58)
05-22 14:50:29.373: E/AndroidRuntime(780):  at android.widget.ListView.setAdapter(ListView.java:462)
05-22 14:50:29.373: E/AndroidRuntime(780):  at OrdersActivity.onCreate(OrdersActivity.java:30)
05-22 14:50:29.373: E/AndroidRuntime(780):  at android.app.Activity.performCreate(Activity.java:5104)
05-22 14:50:29.373: E/AndroidRuntime(780):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
05-22 14:50:29.373: E/AndroidRuntime(780):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
05-22 14:50:29.373: E/AndroidRuntime(780):  ... 11 more

2 个答案:

答案 0 :(得分:1)

在您的OrdersActivity中,您从未初始化作为参数传递给适配器的dHashMap)。

public int getCount() {
    return (data == null) ? 0 : data.size();
}

答案 1 :(得分:0)

你在这里发生异常。

at OrdersAdapter.getCount(OrdersAdapter.java:58)