JSON Parser Low Performance

1

Я перепробовал здесь, чтобы получить некоторую помощь.

Я сделал JSON Parser, который возвращает JSONArray (чтобы получить информацию от моего WebService).

Мой последний код выбросил ошибку NetworkException (в версии 2.3.3 она была длинной, но хорошая работа), когда я тестировал ее на IceScreamSandwich..

Я изменил свой код, чтобы остановить его, и попытаться получить лучшие настройки... но он все еще не работает на моем телефоне ICS: теперь больше нет ошибок, а ioexcepetion: "не удалось прочитать URL-адрес JSON".

Я показываю вам свою деятельность:

public class TabNewsJSONParsingActivity extends ListActivity

{

// url to make request
private static String url = "http://developer.prixo.fr/API/GetEvents?zone=8";

//JSON names
private static final String TAG_content = "content";
private static final String TAG_zone = "zone";
private static final String TAG_id = "id";
private static final String TAG_area = "area";
private static final String TAG_title = "title";
private static final String TAG_date = "date";
private static final String TAG_author = "author";

@Override
public void onCreate(Bundle savedInstanceState) 
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.onglet_news);

    // Hashmap for ListView
    ArrayList<HashMap<String, String>> newsList = new ArrayList<HashMap<String, String>>();

    // Creating JSON Parser instance
    JSONParser jParser = new JSONParser();

    // getting JSON string from URL
    JSONArray json;
    try {
        json = jParser.getJSONFromUrl1(url);

                for(int i=0; i < json.length(); i++)
                {
                    JSONObject child = json.getJSONObject(i);

                    String id = child.getString(TAG_id);
                    String title = child.getString(TAG_title);
                    String content = child.getString(TAG_content);
                    String date = child.getString(TAG_date);
                    String author = child.getString(TAG_author);
                    String zone = child.getString(TAG_zone);
                    String area = child.getString(TAG_area);


                    // creating new HashMap
                    HashMap<String, String> map = new HashMap<String, String>();

                    // adding each child node to HashMap key => value
                    map.put(TAG_content, content);
                    map.put(TAG_title, title);
                    map.put(TAG_author, author);

                    // adding HashList to ArrayList
                    newsList.add(map);
                }
            }
        catch (JSONException e) {
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    /**
     * Updating parsed JSON data into ListView
     * */
    ListAdapter adapter = new SimpleAdapter(this, newsList,R.layout.onglet_news_listitem,new String[] { TAG_content, TAG_title, TAG_author }, new int[] {R.id.name, R.id.email, R.id.mobile });
    setListAdapter(adapter);

    // selecting single ListView item
    ListView lv = getListView();

    // Launching new screen on Selecting Single ListItem
    lv.setOnItemClickListener(new OnItemClickListener() 
    {
        public void onItemClick(AdapterView<?> parent, View view,int position, long id) {
            // getting values from selected ListItem
            String name = ((TextView) view.findViewById(R.id.name)).getText().toString();
            String cost = ((TextView) view.findViewById(R.id.email)).getText().toString();
            String description = ((TextView) view.findViewById(R.id.mobile)).getText().toString();

            // Starting new intent
            Intent in = new Intent(getApplicationContext(), TabNewsSingleMenuItemActivity.class);
            in.putExtra(TAG_content, name);
            in.putExtra(TAG_title, cost);
            in.putExtra(TAG_author, description);
            startActivity(in);

        }
    });
}

public boolean onOptionsItemSelected(MenuItem item) 
{   
   //On regarde quel item a été cliqué grâce à son id et on déclenche une action
   switch (item.getItemId()) 
   {
      case R.id.credits:
         //pop up
        Toast.makeText(TabNewsJSONParsingActivity.this, "Un delire", Toast.LENGTH_SHORT).show();
         return true;
      case R.id.quitter:
         //Pour fermer l'application il suffit de faire finish()
         finish();
         return true;
   }
 return false;  
}

}

И мой Парсер:

открытый класс JSONParser {

static InputStream is = null;
static JSONObject jObj = null;
static String jsonstr = "";

public JSONParser() {}

 // throws IOException just to tell the caller that something bad happened (and 
 // what) instead of simply returning 'null' without any more information.
 public JSONArray getJSONFromUrl1(String url) throws IOException 
 {
     try 
     {
         // should be a member of the parser to allow multiple calls without recreating the client every time.
         DefaultHttpClient httpClient = new DefaultHttpClient();
         // Using POST means sending data (or it its not following HTTP RFCs)
         //HttpPost httpPost = new HttpPost(url);
         HttpGet httpGet = new HttpGet(url);

         // Here the client may not be entirely initialized (no timeout, no agent-string).
         HttpResponse httpResponse = httpClient.execute(httpGet);
         //HttpResponse httpResponse = httpClient.execute(httpPost);

         HttpEntity httpEntity = httpResponse.getEntity();

         // The native utility function is also handling other charsets
         String httpString = EntityUtils.toString(httpEntity);

         return new JSONArray(httpString);
     } catch (IOException ioe) {
     throw ioe;
     } catch (Exception ex) {
     throw new IOException("Failed to read JSON from Url");
     }
 }

}

Кто знает о том, как получить лучшие perfs и сделать его ромом за 4.0? Как использовать его с Async Task? благодаря

Теги:
http
parsing
request

3 ответа

1
Лучший ответ

вам необходимо использовать AsyncTask для загрузки и анализа ваших данных

код ниже

import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.app.ListActivity;
import android.app.ProgressDialog;
import android.content.Intent;
import android.os.AsyncTask;
import android.os.Bundle;
import android.os.StrictMode;
import android.view.MenuItem;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ListAdapter;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.TextView;
import android.widget.Toast;

public class TabNewsJSONParsingActivity extends ListActivity
{
    static{
        StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();

        StrictMode.setThreadPolicy(policy);
    }

    // url to make request
    private static String url = "http://developer.prixo.fr/API/GetEvents?zone=8";

    //JSON names
    private static final String TAG_content = "content";
    private static final String TAG_zone = "zone";
    private static final String TAG_id = "id";
    private static final String TAG_area = "area";
    private static final String TAG_title = "title";
    private static final String TAG_date = "date";
    private static final String TAG_author = "author";

    @Override
    public void onCreate(Bundle savedInstanceState) 
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.onglet_news);



        // selecting single ListView item
        ListView lv = getListView();

        // Launching new screen on Selecting Single ListItem
        lv.setOnItemClickListener(new OnItemClickListener() 
        {
            public void onItemClick(AdapterView<?> parent, View view,int position, long id) {
                // getting values from selected ListItem
                String name = ((TextView) view.findViewById(R.id.name)).getText().toString();
                String cost = ((TextView) view.findViewById(R.id.email)).getText().toString();
                String description = ((TextView) view.findViewById(R.id.mobile)).getText().toString();

                // Starting new intent
                Intent in = new Intent(getApplicationContext(), TabNewsSingleMenuItemActivity.class);
                in.putExtra(TAG_content, name);
                in.putExtra(TAG_title, cost);
                in.putExtra(TAG_author, description);
                startActivity(in);

            }
        });

        new DownloadData().execute();
    }

    public boolean onOptionsItemSelected(MenuItem item) 
    {   
       //On regarde quel item a été cliqué grâce à son id et on déclenche une action
       switch (item.getItemId()) 
       {
          case R.id.credits:
             //pop up
            Toast.makeText(TabNewsJSONParsingActivity.this, "Un delire", Toast.LENGTH_SHORT).show();
             return true;
          case R.id.quitter:
             //Pour fermer l'application il suffit de faire finish()
             finish();
             return true;
       }
     return false;  
    }


    private class DownloadData extends AsyncTask<Void, Integer, ArrayList<HashMap<String, String>>>
    {
        ProgressDialog pd = null;
        /* (non-Javadoc)
         * @see android.os.AsyncTask#onPreExecute()
         */
        @Override
        protected void onPreExecute() {
            // TODO Auto-generated method stub
            super.onPreExecute();

            pd = new ProgressDialog(TabNewsJSONParsingActivity.this);
            pd.setTitle("Downloading...");
            pd.setMessage("Please wait...");
            pd.setCancelable(false);
            pd.show();
        }

        /* (non-Javadoc)
         * @see android.os.AsyncTask#doInBackground(Params[])
         */
        @Override
        protected ArrayList<HashMap<String, String>> doInBackground(Void... params) {
            // TODO Auto-generated method stub

            // Hashmap for ListView
            ArrayList<HashMap<String, String>> newsList = new ArrayList<HashMap<String, String>>();

            // Creating JSON Parser instance
            JSONParser jParser = new JSONParser();

            // getting JSON string from URL
            JSONArray json;
            try {
                json = jParser.getJSONFromUrl1(url);

                        for(int i=0; i < json.length(); i++)
                        {
                            JSONObject child = json.getJSONObject(i);

                            String id = child.getString(TAG_id);
                            String title = child.getString(TAG_title);
                            String content = child.getString(TAG_content);
                            String date = child.getString(TAG_date);
                            String author = child.getString(TAG_author);
                            String zone = child.getString(TAG_zone);
                            String area = child.getString(TAG_area);


                            // creating new HashMap
                            HashMap<String, String> map = new HashMap<String, String>();

                            // adding each child node to HashMap key => value
                            map.put(TAG_content, content);
                            map.put(TAG_title, title);
                            map.put(TAG_author, author);

                            // adding HashList to ArrayList
                            newsList.add(map);
                        }
                    }
                catch (JSONException e) {
                    e.printStackTrace();
                } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }

            return newsList;
        }

        /* (non-Javadoc)
         * @see android.os.AsyncTask#onPostExecute(java.lang.Object)
         */
        @Override
        protected void onPostExecute(ArrayList<HashMap<String, String>> newsList) {
            // TODO Auto-generated method stub
            super.onPostExecute(newsList);
            pd.dismiss();

            /**
             * Updating parsed JSON data into ListView
             * */
            ListAdapter adapter = new SimpleAdapter(TabNewsJSONParsingActivity.this, newsList,R.layout.onglet_news_listitem,new String[] { TAG_content, TAG_title, TAG_author }, new int[] {R.id.name, R.id.email, R.id.mobile });
            TabNewsJSONParsingActivity.this.setListAdapter(adapter);


        }

    }
}
  • 0
    Спасибо, я пробовал это, но у меня есть эта ошибка компиляции в ListAdapter adapter = new SimpleAdapter (..): "Конструктор SimpleAdapter не определен"
  • 0
    @ Queen, пожалуйста, найдите обновленный код. это вызвано this параметром. вместо этого, пожалуйста, используйте TabNewsJSONParsingActivity.this
1

Начать работу AsycnTask:

JSONTask g = new JSONTask();
g.execute();

И некоторый код о том, как вы можете его реализовать;

public abstract class JSONTask extends AsyncTask<String, Void, String> {
@Override
protected String doInBackground(String... arg) {
  //Do http get json here
  String htpStatus= "";
  String httpJSON = "" // this is the json data from you web service

  // Create here your JSONObject...
  JSONObject json = new JSONObject(httpJSON);
  for(int i=0; i < json.length(); i++){
                JSONObject child = json.getJSONObject(i);

                String id = child.getString(TAG_id);
                String title = child.getString(TAG_title);
                String content = child.getString(TAG_content);
                String date = child.getString(TAG_date);
                String author = child.getString(TAG_author);
                String zone = child.getString(TAG_zone);
                String area = child.getString(TAG_area);


                // creating new HashMap
                HashMap<String, String> map = new HashMap<String, String>();

                // adding each child node to HashMap key => value
                map.put(TAG_content, content);
                map.put(TAG_title, title);
                map.put(TAG_author, author);

                // adding HashList to ArrayList
                newsList.add(map);
  }
  return htpStatus; // This value will be returned to your onPostExecute(result) method
}

@Override
protected void onPostExecute(String result) {

}
}
  • 1
    Хороший пример, но я бы проанализировал сообщение JSON внутри метода doInBackground (), чтобы избежать зависания пользовательского интерфейса .. :)
0

Возможно, это связано с тем, что вы запускаете веб-соединения в основном потоке. Попробуйте запустить этот фрагмент кода в AsyncTask или другой поток.

  • 0
    Можете ли вы привести пример структуры асинхронной задачи в сочетании с загружаемым содержимым и моей картой?

Ещё вопросы

Сообщество Overcoder
Наверх
Меню