在我的 android 应用程序中,我将一些数据从服务器数据库复制到本地数据库。这可能需要 15 分钟以上。对于较慢的连接,它可能会被超过。所以我想显示一个等待进度条。
代码贴在下面。
refresh.setOnClickListener(new OnClickListener(){
public void onClick(View v) {
final ProgressDialog progressDialog = ProgressDialog.show(login.this, "", "Please wait...");
new Thread() {
public void run() {
try{
mySQLiteAdapter.openToWrite();
mySQLiteAdapter.deleteAll();
radapter.openToWrite();
radapter.deleteAll();
uadapter.openToWrite();
uadapter.deleteAll();
try
{
HttpClient httpclient = new DefaultHttpClient();
HttpPost httppost = new HttpPost("http://xxxxxxxxxxxxxxxxxxxxx");
HttpResponse response = httpclient.execute(httppost);
HttpEntity entity = response.getEntity();
is = entity.getContent();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
try {
BufferedReader reader = new BufferedReader(new InputStreamReader(
is, "iso-8859-1"), 8);
StringBuilder sb = new StringBuilder();
String line = null;
while ((line = reader.readLine()) != null) {
sb.append(line + "\n");
}
is.close();
json = sb.toString();
} catch (Exception e) {
Toast.makeText(getBaseContext(), e.toString(), Toast.LENGTH_LONG).show();
}
try {
jObj = new JSONObject(json);
contacts = jObj.getJSONArray("get");
for(int i = 0; i < contacts.length(); i++){
JSONObject c = contacts.getJSONObject(i);
if(!c.isNull("rname"))// || c.getString("rcode").equals(null))
{
rname = c.getString("rname");
rcode = c.getString("rcode");
radapter.insert(rcode, rname);
}
else
{
rname = "";
rcode = c.getString("rcode");
radapter.insert(rcode, rname);
}
}
Toast.makeText(getBaseContext(), " Ryot BackUp completed", Toast.LENGTH_SHORT).show();
} catch (JSONException e) {
Toast.makeText(getBaseContext(), "Error"+e.toString(), Toast.LENGTH_LONG).show();
}
progressDialog.dismiss();
}
}.start();
adapter.deleteAll();
oadapter.deleteAll();
e2.setText("Back Up completed");
}
catch (Exception e) {
Log.e("tag", e.getMessage());
}
progressDialog.dismiss();
}
}.start();
}
});
当我运行我的应用程序时,进度条仅显示几秒钟并执行 Catch 块,将 logcat 错误显示为
日志猫:
02-26 14:26:07.151: E/tag(301): Can't create handler inside thread that has not called Looper.prepare()
有人可以解释我的代码中的错误是什么以及如何解决它