AsyncTask를 사용하여 JSON을 사용하는 웹 서비스에서 정보를 가져 오는 안드로이드 응용 프로그램을 개발 중이며,이 JSON은 ListView에로드됩니다. 여기까지는 모든 것이 잘 작동합니다.ProgressDialog 또는 ProgressBar가 Android를 실행하는 응용 프로그램의 속도를 저하시킵니다.
onPreExecute() 메서드에서 시작되어 onPostExecute() 메서드에서 해제 된 ProgressDialog를 사용했습니다. 2.3.3 안드로이드 버전을 실행하는 에뮬레이터에서이 모든 작업은 7/8 초까지 걸립니다. 2.3.6을 실행하는 실제 장치로 테스트 한 결과 앱의 동작이 동일합니다.
그러나 4.1 버전의 Android를 실행하는 에뮬레이터를 사용하면이 작업을 수행하는 데 65-70 초가 소요됩니다. ProgressDialog를 제거하면 액션은 안드로이드 2.3 및 4.1 버전에서 7/8 초가 걸립니다. 나는이 모든 시나리오를 여러 번 테스트했습니다.
왜 이런 일이 발생합니까? 나는 그것을 테스트하는 4.1 안드로이드 버전과 어떤 실제 장치가 없으므로 나는 이것이 에뮬레이터 문제인지 궁금한가요? ProgressDialog 대신 일반 진행률 표시 줄 원을 사용하려고했지만 동일한 문제가 발생합니다. Android 4.1 버전에서는 너무 오래 걸립니다.
이 이상한 동작의 원인이 될 수있는 아이디어가 있습니까? : S
감사합니다.
dmon 및 James McCracken이 여기 내 활동의 코드입니다. 제발 도와주세요.
public class MainActivity extends Activity {
private TextView tvTitleList;
private ListView lvDataSearch;
private ProgressDialog dialog;
private long timeStart;
private String[] dataSearch;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tvTitleList = (TextView) findViewById(R.id.tvTitleList);
lvDataSearch = (ListView) findViewById(R.id.lvDataSearch);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
public class ProcessUpdateList extends AsyncTask<Integer, String, String[]> {
@Override
protected void onPreExecute() {
timeStart = System.currentTimeMillis();
System.out.println("pre execute");
try {
tvTitleList.setText("working....");
dialog = ProgressDialog.show(MainActivity.this, "", "Loading. Please wait...", true);
} catch (Exception e) {
System.out.println("Error Async 1: " + e.getMessage());
}
}
@Override
protected String[] doInBackground(Integer... paramss) {
try {
System.out.println("Get Data");
dataSearch = getDataSearch();
} catch (Exception e) {
System.out.println("Error Async 2: " + e.getMessage());
}
System.out.println("Return Data "
+ ((System.currentTimeMillis() - timeStart)/1000));
return dataSearch;
}
@Override
protected void onPostExecute(String[] values) {
try {
System.out.println("Post Execute Data");
tvTitleList.setText("done in " + ((System.currentTimeMillis() - timeStart)/1000));
updateViewList();
dialog.dismiss();
} catch (Exception e) {
System.out.println("Error Async 3: " + e.getMessage());
}
}
}
public void eventUpdateList() {
ProcessUpdateList process = new ProcessUpdateList();
try {
process.execute();
} catch (Exception e) {
System.out.println("NEW ERROR 2: " + e.getMessage());
}
}
public String[] getDataSearch() {
try {
String readTwitterFeed = readJSON2("http://search.twitter.com/search.json?q=hey");
JSONObject jsonObject = new JSONObject(readTwitterFeed);
JSONArray jsonArray = new JSONArray();
jsonArray.put(jsonObject);
Gson gson = new GsonBuilder().setPrettyPrinting().create();
String json = gson.toJson(jsonObject);
JSONObject jsonObject2 = new JSONObject(json);
JSONObject level1 = jsonObject2.getJSONObject("nameValuePairs");
JSONObject level2 = level1.getJSONObject("results");
JSONArray level3 = level2.getJSONArray("values");
dataSearch = new String[level3.length()];
System.out.println(level3.length()+" resultados encontrados.");;
for(int i=0; i<level3.length(); i++) {
dataSearch[i] = level3.getJSONObject(i).getJSONObject("nameValuePairs").getString("text");
}
}
catch(JSONException e) {
System.out.println(e.getMessage());
}
return dataSearch;
}
public String readJSON2(String command) {
JSONObject jObj = null;
StringBuilder builder = new StringBuilder();
HttpClient client = new DefaultHttpClient();
HttpGet httpGet = new HttpGet(command);
try {
HttpResponse response = client.execute(httpGet);
StatusLine statusLine = response.getStatusLine();
int statusCode = statusLine.getStatusCode();
if (statusCode == 200) {
HttpEntity entity = response.getEntity();
InputStream content = entity.getContent();
BufferedReader reader = new BufferedReader(
new InputStreamReader(content));
String line;
while ((line = reader.readLine()) != null) {
builder.append(line);
}
reader.close();
jObj = new JSONObject(builder.toString());
} else {
System.out.println(MainActivity.class.toString() + " Failed to download file");
}
} catch (Exception e) {
return null;
}
return builder.toString();
}
public void updateViewList() {
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, android.R.id.text1, dataSearch);
lvDataSearch.setAdapter(adapter);
}
public void clickBRefreshList(View v) {
eventUpdateList();
}
}
나는 이것이 일어날 이유를 생각할 수 없다. 로그를 게시 할 수 있습니까? –
뭔가보기에 위력이 들지만 시간이 좀 걸릴 것입니다. 또한 0.875 초 또는 "7 또는 8"초를 의미하는지 여부도 분명하지 않습니다. 만약 당신이 7 - 8을 의미한다면, 무엇인가가 틀린 것입니다. AsyncTask에 대한 코드를 게시해야합니다. – dmon