I created a layout named activity_category and activity named CategoryActivity the code of which is as follows
public class CategoryActivity extends Activity {
    private LazyItemLoadAdapter adapter;
    private int[] selectionId;
    private Item[] item_data;
    private GridView grid;
    private TextView textview;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS);
        setContentView(R.layout.activity_category);
        ActionBarUtils.setActionBar(this);
        String id=getIntent().getExtras().getString("id");
        try{
            AsyncData data=new AsyncData();
            data.execute(Constants.SERVER+"cat_adlist.php?id="+id);
            grid = (GridView) findViewById(R.id.gridViewAllItems);
        }catch(NotFoundException n){
        }
    }
    private class AsyncData extends AsyncTask<String, Void, Item[]>{
        @Override
        protected void onPreExecute() {
            // TODO Auto-generated method stub
            super.onPreExecute();
            setProgressBarIndeterminateVisibility(true);
        }
        @Override
        protected Item[] doInBackground(String... params) {
            String str=null;
            try {
                str = CustomHttpClient
                        .executeHttpGet(params[0]);
                Log.i("Category Data", str);
                JSONArray array = new JSONArray(str);
                item_data = new Item[array.length()];
                selectionId = new int[array.length()];
                for (int i = 0; i < item_data.length; i++) {
                    JSONObject jdata = array.getJSONObject(i);
                    String path = Constants.THUMBS
                            + jdata.getString("name");
                    int itemid = jdata.getInt("id");
                    item_data[i] = new Item(itemid, path, jdata.getString("title"),
                            jdata.getString("price"));
                    selectionId[i] = jdata.getInt("subcategory_id");// change the
                                                                    // field name
                                                                    // here
                }
            }catch(JSONException j){
            } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            return item_data;
        }
        @Override
        protected void onPostExecute(Item[] result) {
            adapter = new LazyItemLoadAdapter(CategoryActivity.this, R.layout.text_below_images, result);
            grid.setAdapter(adapter);
            if (result.length == 0) {
                grid.setVisibility(View.GONE);
                textview.setVisibility(View.VISIBLE);
            } else {
                grid.setVisibility(View.VISIBLE);
                textview.setVisibility(View.GONE);
            }
            TextView numResults=(TextView) findViewById(R.id.textView2);
            numResults.setText("Found "+String.valueOf(result.length)+" results");
            setProgressBarIndeterminateVisibility(false);
            super.onPostExecute(result);
        }
    }
}
The logcat is as follows -
05-07 17:09:58.340: E/AndroidRuntime(2242): FATAL EXCEPTION: main
05-07 17:09:58.340: E/AndroidRuntime(2242): Process: com.opaxlabs.salepurchase, PID: 2242
05-07 17:09:58.340: E/AndroidRuntime(2242): java.lang.NullPointerException
05-07 17:09:58.340: E/AndroidRuntime(2242):     at com.opaxlabs.salepurchase.CategoryActivity$AsyncData.onPostExecute(CategoryActivity.java:115)
05-07 17:09:58.340: E/AndroidRuntime(2242):     at com.opaxlabs.salepurchase.CategoryActivity$AsyncData.onPostExecute(CategoryActivity.java:1)
05-07 17:09:58.340: E/AndroidRuntime(2242):     at android.os.AsyncTask.finish(AsyncTask.java:632)
05-07 17:09:58.340: E/AndroidRuntime(2242):     at android.os.AsyncTask.access$600(AsyncTask.java:177)
05-07 17:09:58.340: E/AndroidRuntime(2242):     at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:645)
05-07 17:09:58.340: E/AndroidRuntime(2242):     at android.os.Handler.dispatchMessage(Handler.java:102)
05-07 17:09:58.340: E/AndroidRuntime(2242):     at android.os.Looper.loop(Looper.java:136)
05-07 17:09:58.340: E/AndroidRuntime(2242):     at android.app.ActivityThread.main(ActivityThread.java:5017)
05-07 17:09:58.340: E/AndroidRuntime(2242):     at java.lang.reflect.Method.invokeNative(Native Method)
05-07 17:09:58.340: E/AndroidRuntime(2242):     at java.lang.reflect.Method.invoke(Method.java:515)
05-07 17:09:58.340: E/AndroidRuntime(2242):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
05-07 17:09:58.340: E/AndroidRuntime(2242):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
05-07 17:09:58.340: E/AndroidRuntime(2242):     at dalvik.system.NativeStart.main(Native Method)
As you can see I am getting a null pointer exception. initially it was because I was using a wrong layout but I have corrected that but the problem persists. Please help me with your suggestions. Thanks in advance.
 
     
     
    